鏈?zhǔn)骄幊痰暮唵问褂?/h1>

磚搬久了狈涮,慢慢會發(fā)現(xiàn)很多時間總會在做些重復(fù)的事情授帕,這個時候我們就會習(xí)慣性的去考慮怎么去省事,這也是我之所以突然想到用鏈?zhǔn)骄幊痰脑蚓穑瑥U話不多說黍氮,先舉個例子,以初始化一個UIButton為例來看看鏈?zhǔn)骄幊痰男Ч?/p>

鏈?zhǔn)骄幊?png

1浅浮、普通方案

    UIButton *button =[UIButton buttonWithType:UIButtonTypeCustom];
    button.frame=CGRectMake(0, 0, 105, 30);
    [button setBackgroundColor:RGB(255,255,255) forState:UIControlStateNormal];
    [button setTitle:@"title" forState:UIControlStateNormal];
    [button setImage:[UIImage imageNamed:@"drop_up"] forState:UIControlStateNormal];
    [button setImage:[UIImage imageNamed:@"drop_down"] forState:UIControlStateSelected];
    [button setTitleColor:RGB(51,51,51) forState:UIControlStateNormal];
    [button setTitleColor:RGB(51,51,51) forState:UIControlStateSelected];
    button.titleLabel.font=[UIFont systemFontOfSize:14];

2沫浆、鏈?zhǔn)骄幊谭桨?/p>

UIButton *button =[UIButton buttonWithType:UIButtonTypeCustom];
   button.normalTitleColor(RGB(51,51,51)).selectedTitleColor(RGB(51,51,51)).normalBackgroundColor(RGB(255,255,255)).selectedBackgroundColor(RGB(255,255,255)).normalImage(@"drop_up").selectedImage(@"drop_down").normalTitle(@"title");

總結(jié):
個人覺得第二種方案在實(shí)際開發(fā)中使用會比第一種稍微便捷一點(diǎn),每次設(shè)置對應(yīng)屬性的時候直接使用點(diǎn)語法就可以了滚秩,而且還可以一直往后面點(diǎn)专执,也可以分開單個使用點(diǎn)語法,不需要每次去調(diào)用系統(tǒng)UIButton的set方法郁油,而且還要去輸入當(dāng)前的狀態(tài)本股,
以上為個人意見不喜勿碰攀痊,謝謝!

??接下來看看封裝的代碼的真面目吧--------

創(chuàng)建一個UIButton的類別拄显,下面附上.h苟径、.m文件中實(shí)現(xiàn)代碼,感興趣的可以參照我寫的幾個拓展出更多來躬审,如果有更簡便的方案歡迎聯(lián)系我一起溝通學(xué)習(xí) ????

UIButton+Button.h
#import <UIKit/UIKit.h>

@interface UIButton (Button)
/**
 字體大小
 */
-(UIButton *(^)(CGFloat ))butTexFont;
/**
 默認(rèn)文字
 */
-(UIButton *(^)(NSString *))normalTitle;
/**
 點(diǎn)擊文字
 */
-(UIButton *(^)(NSString *))selectedTitle;
/**
 默認(rèn)背景顏色
 */
-(UIButton *(^)(UIColor *))normalBackgroundColor;
/**
 點(diǎn)擊背景顏色
 */
-(UIButton *(^)(UIColor *))selectedBackgroundColor;
/**
 默認(rèn)文字顏色
 */
-(UIButton *(^)(UIColor *))normalTitleColor;
/**
 點(diǎn)擊文字顏色
 */
-(UIButton *(^)(UIColor *))selectedTitleColor;

/**
 默認(rèn)image
 */
-(UIButton *(^)(NSString *))normalImage;
/**
 點(diǎn)擊image
 */
-(UIButton *(^)(NSString *))selectedImage;
@end
UIButton+Button.m

#import "UIButton+Button.h"

@implementation UIButton (Button)
#pragma mark -- 字體大小
-(UIButton *(^)(CGFloat))butTexFont
{
    return ^id(CGFloat butTexFont)
    {
        self.titleLabel.font=[UIFont systemFontOfSize:butTexFont];
        return self;
    };
}
#pragma mark --默認(rèn)文字
-(UIButton *(^)(NSString *))normalTitle{
    return ^id(NSString * normalTitle){
        [self setTitle:normalTitle forState:UIControlStateNormal];
        return self;
    };
}
#pragma mark ---點(diǎn)擊文字
-(UIButton *(^)(NSString *))selectedTitle{
    return ^id(NSString * selectedTitle){
        [self setTitle:selectedTitle forState:UIControlStateSelected];
        return self;
    };
}
#pragma mark --默認(rèn)image
-(UIButton *(^)(NSString *))normalImage{
    return ^id(NSString * normalImage){
        [self setImage:[UIImage imageNamed:normalImage] forState:UIControlStateNormal];
        return self;
    };
}
#pragma mark ---點(diǎn)擊image
-(UIButton *(^)(NSString *))selectedImage{
    return ^id(NSString * selectedImage){
        [self setImage:[UIImage imageNamed:selectedImage] forState:UIControlStateSelected];
        return self;
    };
}
#pragma mark --默認(rèn)背景顏色
-(UIButton *(^)(UIColor *))normalBackgroundColor{
    return ^id(UIColor * normalBackgroundColor){
        [self setBackgroundColor:normalBackgroundColor forState:UIControlStateNormal];
        return self;
    };
}
#pragma mark --點(diǎn)擊背景顏色
-(UIButton *(^)(UIColor *))selectedBackgroundColor{
    return ^id(UIColor * selectedBackgroundColor){
        [self setBackgroundColor:selectedBackgroundColor forState:UIControlStateSelected];
        return self;
    };
}
#pragma mark ---默認(rèn)文字顏色
-(UIButton *(^)(UIColor *))normalTitleColor{
    return ^id(UIColor * normalTitleColor){
        [self setTitleColor:normalTitleColor forState:UIControlStateNormal];
        return self;
    };
}
#pragma mark ---點(diǎn)擊文字顏色
-(UIButton *(^)(UIColor *))selectedTitleColor{
    return ^id(UIColor * selectedTitleColor){
        [self setTitleColor:selectedTitleColor forState:UIControlStateSelected];
        return self;
    };
}
@end
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者

  • 序言:七十年代末棘街,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子承边,更是在濱河造成了極大的恐慌遭殉,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,222評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件博助,死亡現(xiàn)場離奇詭異险污,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)翔始,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,455評論 3 385
  • 文/潘曉璐 我一進(jìn)店門罗心,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人城瞎,你說我怎么就攤上這事渤闷。” “怎么了脖镀?”我有些...
    開封第一講書人閱讀 157,720評論 0 348
  • 文/不壞的土叔 我叫張陵飒箭,是天一觀的道長。 經(jīng)常有香客問我蜒灰,道長弦蹂,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,568評論 1 284
  • 正文 為了忘掉前任强窖,我火速辦了婚禮凸椿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘翅溺。我一直安慰自己脑漫,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,696評論 6 386
  • 文/花漫 我一把揭開白布咙崎。 她就那樣靜靜地躺著优幸,像睡著了一般。 火紅的嫁衣襯著肌膚如雪褪猛。 梳的紋絲不亂的頭發(fā)上网杆,一...
    開封第一講書人閱讀 49,879評論 1 290
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼碳却。 笑死队秩,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的追城。 我是一名探鬼主播刹碾,決...
    沈念sama閱讀 39,028評論 3 409
  • 文/蒼蘭香墨 我猛地睜開眼燥撞,長吁一口氣:“原來是場噩夢啊……” “哼座柱!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起物舒,我...
    開封第一講書人閱讀 37,773評論 0 268
  • 序言:老撾萬榮一對情侶失蹤色洞,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后冠胯,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體火诸,經(jīng)...
    沈念sama閱讀 44,220評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,550評論 2 327
  • 正文 我和宋清朗相戀三年荠察,在試婚紗的時候發(fā)現(xiàn)自己被綠了置蜀。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,697評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡悉盆,死狀恐怖盯荤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情焕盟,我是刑警寧澤秋秤,帶...
    沈念sama閱讀 34,360評論 4 332
  • 正文 年R本政府宣布,位于F島的核電站脚翘,受9級特大地震影響灼卢,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜来农,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,002評論 3 315
  • 文/蒙蒙 一鞋真、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧沃于,春花似錦涩咖、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,782評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至蒋困,卻和暖如春盾似,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,010評論 1 266
  • 我被黑心中介騙來泰國打工零院, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留溉跃,地道東北人。 一個月前我還...
    沈念sama閱讀 46,433評論 2 360
  • 正文 我出身青樓告抄,卻偏偏與公主長得像撰茎,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子打洼,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,587評論 2 350

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