iOS開發(fā)中的常用技巧--工廠模式及自定義config

已經(jīng)有一個(gè)多月沒有更新博客了,過完年回來我完成了Strong好書項(xiàng)目的學(xué)習(xí),已為自己正在開發(fā)的項(xiàng)目打基礎(chǔ).今天就在這里總結(jié)一下其中學(xué)到的工廠模式及自定義config

工廠模式

我們在開發(fā)中可能會(huì)遇到一些按鈕組件,或者某些功能在很多界面都會(huì)用到的情況,如果每次用到時(shí)都要重寫一遍代碼,那就十分費(fèi)時(shí)費(fèi)力.我們可以利用工廠模式,把這一系列的類型放在工廠當(dāng)中,這樣我們在創(chuàng)建這些相同屬性時(shí)不用重復(fù)寫代碼,只需要用繼承或者函數(shù)的方法來調(diào)用即可.

在好書項(xiàng)目中,自定義了頂部的兩個(gè)button,在多個(gè)界面中都會(huì)用到,因此我們可以新建一個(gè).swift文件


GeneralFactory.png

然后用代碼實(shí)現(xiàn)頂部的兩個(gè)按鈕

import UIKit

class GeneralFactory: NSObject {
    //靜態(tài)方法,創(chuàng)建兩個(gè)頂部的按鈕
    static func addTitelWithTile(target:UIViewController,title1:String = "關(guān)閉",title2:String = "確認(rèn)") {
        
        let btn1 = UIButton(frame: CGRectMake(10,20,40,20))
        btn1.setTitle(title1, forState: .Normal)
        btn1.contentHorizontalAlignment = .Left
        btn1.setTitleColor(MAIN_RED, forState: .Normal)
        btn1.titleLabel?.font = UIFont(name: MY_FONT, size: 16)
        btn1.tag = 1111
        target.view.addSubview(btn1)
        
        
        let btn2 = UIButton(frame: CGRectMake(SCREEN_WIDTH - 50,20,40,20))
        btn2.setTitle(title2, forState: .Normal)
        btn2.contentHorizontalAlignment = .Right
        btn2.setTitleColor(MAIN_RED, forState: .Normal)
        btn2.titleLabel?.font = UIFont(name: MY_FONT, size: 16)
        btn2.tag = 2222
        target.view.addSubview(btn2)
        //此做法比較危險(xiǎn),注意在調(diào)用這個(gè)方法時(shí)要?jiǎng)?chuàng)建close和sure的方法
        btn1.addTarget(target, action: "close", forControlEvents: .TouchUpInside)
        btn2.addTarget(target, action: "sure", forControlEvents: .TouchUpInside)
    }

}

然后在相應(yīng)的界面進(jìn)行調(diào)用即可,比如我們要在新建書評界面添加這兩個(gè)button

    func pushNewBook() {
        let vc = pushNewBookViewController()
        GeneralFactory.addTitelWithTile(vc, title1: "關(guān)閉", title2: "發(fā)布")
        self.presentViewController(vc, animated: true) { () -> Void in
            
        }
    }
新建書評.png

這樣就添加上了,但是別忘了在你push過去的界面VC中添加sure和colse方法

    func close() {
        self.dismissViewControllerAnimated(true) { () -> Void in
            
        }
    }
    
    func sure() {
        
        //獲取輸入的內(nèi)容,已字典的形式來創(chuàng)建
        let dict = [
            "bookName":(self.bookTitle?.bookName?.text)!,
            "bookEditor":(self.bookTitle?.bookEditor?.text)!,
            "bookCover":(self.bookTitle?.bookCover?.currentImage)!,
            "title":self.Book_Title,
            "score":String((self.score?.show_star)!),
            "type":self.type,
            "detaileType":self.detaiType,
            "description":self.Book_Description
        ]
        ProgressHUD.show("")
        if self.fixType == "fix" {
            pushBook.pushBookInBack(dict, object: self.BookObject!)
        }else {
            let object = AVObject(className: "Book")
            pushBook.pushBookInBack(dict, object: object)
        }
    }

自定義config

為了方便開發(fā),我們還可以把我們經(jīng)常會(huì)用到的一些屬性添加到自建的config.swift中,這樣也能減少我們的代碼重復(fù).
好書項(xiàng)目中在config中定義了幾個(gè)經(jīng)常使用的常量:屏幕寬度;屏幕高度;常用顏色;常用字體.和一個(gè)方法用來自定義顏色.

第一步還是新建.swift文件

config.png

第二步,代碼實(shí)現(xiàn)

import Foundation

//定義三個(gè)常量可以全局調(diào)用
//SCREEN_WIDTH在使用屏幕寬度時(shí)可以調(diào)用
let SCREEN_WIDTH = UIScreen.mainScreen().bounds.size.width
//SCREEN_HEIGHT在使用屏幕高度時(shí)可以調(diào)用
let SCREEN_HEIGHT = UIScreen.mainScreen().bounds.size.height
//MAIN_RED在使用字體顏色時(shí)可以調(diào)用
let MAIN_RED = UIColor(colorLiteralRed: 235/255, green: 144/255, blue: 110/255, alpha: 1)
//MY_FONT在使用字體時(shí)可以調(diào)用
let MY_FONT = "Bauhaus ITC"

func RGB(r:Float,g:Float,b:Float) -> UIColor {
    return UIColor(colorLiteralRed: r/255.0, green: g/255.0, blue: b/255.0, alpha: 1)
}

這樣我們需要用到屏幕寬度,顏色等的情況下就可以直接調(diào)用SCREEN_WIDTH而不用再寫UIScreen.mainScreen().bounds.size.width了

    override func viewDidLoad() {
        super.viewDidLoad()

        self.view.backgroundColor = UIColor.whiteColor()
        //創(chuàng)建之前在V中寫好的BookTitleView
        self.bookTitle = BookTitleView(frame: CGRectMake(0,40,SCREEN_WIDTH,160))
        self.bookTitle?.delegate = self
        self.view.addSubview(self.bookTitle!)
        
        self.tableView = UITableView(frame: CGRectMake(0, 200, SCREEN_WIDTH, SCREEN_HEIGHT-200),style:.Grouped)
        //下面的代碼會(huì)使沒有內(nèi)容的線條消失
        self.tableView?.tableFooterView = UIView()
        self.tableView?.delegate = self
        self.tableView?.dataSource = self
        //注冊cell的identifier
        self.tableView?.registerClass(UITableViewCell.classForCoder(), forCellReuseIdentifier: "cell")
        self.tableView?.backgroundColor = UIColor(colorLiteralRed: 250/255, green: 250/255, blue: 250/255, alpha: 1)
        self.view.addSubview(self.tableView!)

        
    }

以上兩個(gè)方法十分簡單實(shí)用,我們在開發(fā)當(dāng)中也會(huì)經(jīng)常遇到

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市净响,隨后出現(xiàn)的幾起案子骆莹,更是在濱河造成了極大的恐慌肛冶,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,376評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)垢村,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來嚎卫,“玉大人嘉栓,你說我怎么就攤上這事⊥刂睿” “怎么了侵佃?”我有些...
    開封第一講書人閱讀 156,966評論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長奠支。 經(jīng)常有香客問我馋辈,道長,這世上最難降的妖魔是什么倍谜? 我笑而不...
    開封第一講書人閱讀 56,432評論 1 283
  • 正文 為了忘掉前任迈螟,我火速辦了婚禮,結(jié)果婚禮上尔崔,老公的妹妹穿的比我還像新娘答毫。我一直安慰自己,他們只是感情好季春,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,519評論 6 385
  • 文/花漫 我一把揭開白布洗搂。 她就那樣靜靜地躺著,像睡著了一般载弄。 火紅的嫁衣襯著肌膚如雪耘拇。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,792評論 1 290
  • 那天侦锯,我揣著相機(jī)與錄音驼鞭,去河邊找鬼秦驯。 笑死尺碰,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的译隘。 我是一名探鬼主播亲桥,決...
    沈念sama閱讀 38,933評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼固耘!你這毒婦竟也來了题篷?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,701評論 0 266
  • 序言:老撾萬榮一對情侶失蹤厅目,失蹤者是張志新(化名)和其女友劉穎番枚,沒想到半個(gè)月后法严,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,143評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡葫笼,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,488評論 2 327
  • 正文 我和宋清朗相戀三年深啤,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片路星。...
    茶點(diǎn)故事閱讀 38,626評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡溯街,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出洋丐,到底是詐尸還是另有隱情呈昔,我是刑警寧澤,帶...
    沈念sama閱讀 34,292評論 4 329
  • 正文 年R本政府宣布友绝,位于F島的核電站堤尾,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏迁客。R本人自食惡果不足惜哀峻,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,896評論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望哲泊。 院中可真熱鬧剩蟀,春花似錦、人聲如沸切威。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽先朦。三九已至缰冤,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間喳魏,已是汗流浹背棉浸。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留刺彩,地道東北人迷郑。 一個(gè)月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像创倔,于是被迫代替她去往敵國和親嗡害。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,494評論 2 348

推薦閱讀更多精彩內(nèi)容