iOS開發(fā)之XLForm的使用

在iOS開發(fā)中授帕,開發(fā)"表單"界面,字段稍微多一點(diǎn)的一般都用UITableView來做浮梢,而XLForm就是這樣一個框架跛十,它是創(chuàng)建動態(tài)表格視圖最牛逼的iOS庫, 用它實現(xiàn)表單功能秕硝,非常簡單芥映,省心省力。但是很可惜,搜索了很多文章都只是翻譯官方文檔奈偏,很多人在使用該庫的時候可能都被官方文檔帶走遠(yuǎn)了坞嘀,不知道如何具體使用。正好最近也要用到這個庫霎苗,所以寫個入門使用文章供大家參考姆吭。

一、 導(dǎo)入項目

使用CocoaPods或者手動導(dǎo)入庫文件唁盏,本人選擇直接導(dǎo)入項目源文件的方式内狸。


導(dǎo)入項目.png

二、改造表單ViewController

ViewController繼承自XLFormViewController,并重寫下面的兩個方法

@interface OneViewController : XLFormViewController

@end


@implementation OneViewController

- (instancetype)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil {
    self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
    if (self){
        [self initializeForm];
    }
    return self;
}

- (id)initWithCoder:(NSCoder *)aDecoder {
    self = [super initWithCoder:aDecoder];
    if (self){
        [self initializeForm];
    }
    return self;
}
@end

三厘擂、構(gòu)造表單

- (void)initializeForm {
    
    // 設(shè)置是否顯示Cell之間分界線
    //self.tableView.separatorStyle = UITableViewCellSeparatorStyleNone;
    // 設(shè)置Section的高度
    self.tableView.sectionHeaderHeight = 30;
    
    XLFormDescriptor * form;//form昆淡,一個表單只有一個
    XLFormSectionDescriptor * section;//section,一個表單可能有多個
    XLFormRowDescriptor * row; //row刽严,每個section可能有多個row
    
    // Form
    form = [XLFormDescriptor formDescriptor];

    
    // First section
    section = [XLFormSectionDescriptor formSection];
    section.title = @"用戶";
    [form addFormSection:section];
    // 普通文本
    row = [XLFormRowDescriptor formRowDescriptorWithTag:@"username" rowType:XLFormRowDescriptorTypeText];
    // 設(shè)置placeholder
    [row.cellConfig setObject:@"用戶名" forKey:@"textField.placeholder"];
    // 設(shè)置文本顏色
    [row.cellConfig setObject:[UIColor redColor] forKey:@"textField.textColor"];
    [section addFormRow:row];
    // 密碼
    row = [XLFormRowDescriptor formRowDescriptorWithTag:@"password" rowType:XLFormRowDescriptorTypePassword];
    // 設(shè)置placeholder的顏色
    NSAttributedString *attrString = [[NSAttributedString alloc] initWithString:@"密碼" attributes:
                                      @{NSForegroundColorAttributeName:[UIColor greenColor],
                                        }];
    [row.cellConfig setObject:attrString forKey:@"textField.attributedPlaceholder"];
    [section addFormRow:row];
    
    
    
    // Second Section
    section = [XLFormSectionDescriptor formSection];
    section.title = @"日期";
    [form addFormSection:section];
    // 日期選擇器
    row = [XLFormRowDescriptor formRowDescriptorWithTag:@"birthday" rowType:XLFormRowDescriptorTypeDate title:@"出生日期"];
    row.value = [NSDate dateWithTimeIntervalSinceNow:60*60*24];
    [section addFormRow:row];
    
    
    
     // Third Section
    section = [XLFormSectionDescriptor formSection];
    section.title = @"頭像";
    [form addFormSection:section];
    // 圖片選擇
    row = [XLFormRowDescriptor formRowDescriptorWithTag:@"userpic" rowType:XLFormRowDescriptorTypeImage];
    [section addFormRow:row];
    
    
    
    // Fourth Section
    section = [XLFormSectionDescriptor formSection];
    section.title = @"選擇器";
    [form addFormSection:section];
    // 選擇器
    row = [XLFormRowDescriptor formRowDescriptorWithTag:@"sex" rowType:XLFormRowDescriptorTypeSelectorPush];
    row.noValueDisplayText = @"暫無";
    row.selectorTitle = @"性別選擇";
    row.selectorOptions = @[@"男",@"女",@"其他"];
    row.title = @"性別";
    [row.cellConfigForSelector setObject:[UIColor redColor] forKey:@"textLabel.textColor"];
    [row.cellConfigForSelector setObject:[UIColor greenColor] forKey:@"detailTextLabel.textColor"];
    [section addFormRow:row];
    
    
    
    // Fifth Section
    section = [XLFormSectionDescriptor formSection];
    section.title = @"加固";
    [form addFormSection:section];
    // 開關(guān)
    row = [XLFormRowDescriptor formRowDescriptorWithTag:@"enforce" rowType:XLFormRowDescriptorTypeBooleanSwitch title:@"加固"];
    [section addFormRow:row];
    
    
    // Sixth Section
    section = [XLFormSectionDescriptor formSection];
    [form addFormSection:section];
    // 按鈕
    row = [XLFormRowDescriptor formRowDescriptorWithTag:@"conform" rowType:XLFormRowDescriptorTypeButton];
    row.title = @"確定";
    [section addFormRow:row];
    

    self.form = form;
}

-(void)didSelectFormRow:(XLFormRowDescriptor *)formRow{

    // 判斷是不是點(diǎn)擊了確定按鈕
    if([formRow.tag isEqualToString:@"conform"] && formRow.rowType == XLFormRowDescriptorTypeButton){

        //獲取表單所有到的值
        NSDictionary *values =  [self formValues];

        NSLog(@"%@", values);

    }
    
    [super didSelectFormRow:formRow];

}

//重寫改該方法 上面的方法就不會調(diào)用了
//-(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{
//
//    NSLog(@"%s", __func__);
//
//}


@end

四昂灵、效果圖

效果圖.png

五、總結(jié)

前面兩步是官方文檔中可以找到的舞萄,也很簡單眨补,關(guān)鍵在于initializeForm方法中具體構(gòu)造表單的過程,這里有必要強(qiáng)調(diào)幾點(diǎn):

  1. XLFormViewController實現(xiàn)了UITableViewDataSource, UITableViewDelegate倒脓,并且持有一個UITableView撑螺,這個從該類的聲明可以看出來,所以UITableView 崎弃、UITableViewDataSource, UITableViewDelegate中的方法都可以正常使用甘晤。
@interface XLFormViewController : UIViewController<UITableViewDataSource, UITableViewDelegate, XLFormDescriptorDelegate, UITextFieldDelegate, UITextViewDelegate, XLFormViewControllerDelegate>
  1. XLForm將表單抽象為FormSection饲做,Row三個層次线婚,分別對應(yīng)三個類
XLFormDescriptor * form;//form,一個表單只有一個
XLFormSectionDescriptor * section;//section盆均,一個表單可能有多個
XLFormRowDescriptor * row; //row塞弊,每個section可能有多個row
  1. 每個表單中的具體信息最后都落腳到XLFormRowDescriptor中,通過它可以配置不同樣式的表單項泪姨,通過構(gòu)造函數(shù)的rowType指定具體的表單類型游沿,該框架提供了非常豐富的rowType,具體可以參考官方文檔說明驴娃。

  2. 更細(xì)化配置表單項就需要借助于XLFormRowDescriptor中的屬性進(jìn)行配置奏候,常用的有

@property (nonatomic, readonly, nonnull) NSMutableDictionary * cellConfig;
@property (nonatomic, readonly, nonnull) NSMutableDictionary * cellConfigForSelector;

這個配置的時候,往往有同學(xué)不知道具體如何才能設(shè)置屬性唇敞,比如怎么設(shè)置表單輸入框的placeholder?更進(jìn)一步如何設(shè)置placeholder 的顏色蔗草。其實它用到了KVC咒彤,因為它們兩個都是UITextField類中的屬性,那么直接進(jìn)入UITextField查找咒精,發(fā)現(xiàn)如下信息:

@property(nullable, nonatomic,copy)   NSString               *placeholder;   
@property(nullable, nonatomic,copy)   NSAttributedString     *attributedPlaceholder NS_AVAILABLE_IOS(6_0); 

那么設(shè)置起來就是

 [row.cellConfig setObject:@"用戶名" forKey:@"textField.placeholder"];
 [row.cellConfig setObject:attrString forKey:@"textField.attributedPlaceholder"];

注意這里的key的寫法镶柱,就是KVC的寫法。其他的屬性依此類推模叙。

  1. 如何獲取設(shè)置好的表單的值歇拆?其實非常簡單,該框架提供一個方法formValues范咨,它的返回類型是一個NSDictionary故觅,其中key就是XLFormRowDescriptor設(shè)置時的Tag∏。可以直接在控制器中調(diào)用該方法獲取表單值输吏,上面的效果圖設(shè)置后的表單信息如下:
    表單信息.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市替蛉,隨后出現(xiàn)的幾起案子贯溅,更是在濱河造成了極大的恐慌,老刑警劉巖躲查,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件它浅,死亡現(xiàn)場離奇詭異,居然都是意外死亡镣煮,警方通過查閱死者的電腦和手機(jī)姐霍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來怎静,“玉大人邮弹,你說我怎么就攤上這事黔衡◎酒福” “怎么了?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵盟劫,是天一觀的道長夜牡。 經(jīng)常有香客問我,道長侣签,這世上最難降的妖魔是什么塘装? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮影所,結(jié)果婚禮上蹦肴,老公的妹妹穿的比我還像新娘。我一直安慰自己猴娩,他們只是感情好阴幌,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布勺阐。 她就那樣靜靜地躺著,像睡著了一般矛双。 火紅的嫁衣襯著肌膚如雪渊抽。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天议忽,我揣著相機(jī)與錄音懒闷,去河邊找鬼。 笑死栈幸,一個胖子當(dāng)著我的面吹牛愤估,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播速址,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼灵疮,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了壳繁?” 一聲冷哼從身側(cè)響起尚粘,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤戏阅,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體腺怯,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年赚哗,在試婚紗的時候發(fā)現(xiàn)自己被綠了蟋字。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡嗅钻,死狀恐怖皂冰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情养篓,我是刑警寧澤秃流,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站柳弄,受9級特大地震影響舶胀,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜碧注,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一嚣伐、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧萍丐,春花似錦轩端、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽刻撒。三九已至,卻和暖如春耿导,著一層夾襖步出監(jiān)牢的瞬間声怔,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工舱呻, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留醋火,地道東北人。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓箱吕,卻偏偏與公主長得像芥驳,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子茬高,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評論 2 353

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

  • —兆旬、改造表單ViewController 讓ViewController繼承自XLFormViewControll...
    sheldon_龍閱讀 555評論 0 1
  • XLForm 目的 XLForm是創(chuàng)建動態(tài)表格視圖最靈活、最強(qiáng)大的iOS庫怎栽。 本庫的目的是像手動創(chuàng)建一樣,實現(xiàn)表單...
    Mob_Developer閱讀 8,114評論 17 22
  • iOS開發(fā)系列--網(wǎng)絡(luò)開發(fā) 概覽 大部分應(yīng)用程序都或多或少會牽扯到網(wǎng)絡(luò)開發(fā)丽猬,例如說新浪微博、微信等熏瞄,這些應(yīng)用本身可...
    lichengjin閱讀 3,657評論 2 7
  • 吃午飯時脚祟,和父親聊天,說著他對當(dāng)下緊張形勢的憂慮强饮。 一方面是對病情的憂慮由桌,我的城市也有一些感染者,甚至我所居的鎮(zhèn)也...
    近墨者_(dá)8a3a閱讀 229評論 2 6
  • 幾塊由碗口粗的雜樹劈成的兩尺多長的木柴架在火塘里邮丰,用細(xì)樹枝引火行您,淡淡的青煙散開、收攏剪廉、向上從屋頂瓦縫飄出屋外娃循,火苗...
    靜夜聽雨_787f閱讀 507評論 2 21