欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS開發(fā)教程之XLForm的基本使用方法

 更新時間:2018年04月26日 11:04:04   作者:YungFan  
XLForm 是最靈活且最強(qiáng)大的創(chuàng)建動態(tài)表單的iOS庫,下面這篇文章主要給大家介紹了關(guān)于iOS開發(fā)教程之XLForm的基本使用方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。

前言

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

以下是這個庫一個簡單的結(jié)構(gòu)圖:

一、 導(dǎo)入項目

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


導(dǎo)入項目

二、改造表單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{
 // 判斷是不是點擊了確定按鈕
 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

四、效果圖


五、總結(jié)

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

1、XLFormViewController實現(xiàn)了UITableViewDataSource, UITableViewDelegate,并且持有一個UITableView,這個從該類的聲明可以看出來,所以UITableView 、UITableViewDataSource, UITableViewDelegate中的方法都可以正常使用。

@interface XLFormViewController : UIViewController<UITableViewDataSource, UITableViewDelegate,XLFormDescriptorDelegate, UITextFieldDelegate, UITextViewDelegate, XLFormViewControllerDelegate>

2、XLForm將表單抽象為Form,Section,Row三個層次,分別對應(yīng)三個類

XLFormDescriptor * form;//form,一個表單只有一個
XLFormSectionDescriptor * section;//section,一個表單可能有多個
XLFormRowDescriptor * row; //row,每個section可能有多個row

3、每個表單中的具體信息最后都落腳到XLFormRowDescriptor中,通過它可以配置不同樣式的表單項,通過構(gòu)造函數(shù)的rowType指定具體的表單類型,該框架提供了非常豐富的rowType,具體可以參考官方文檔說明。

4、更細(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的寫法。其他的屬性依此類推。

5、如何獲取設(shè)置好的表單的值?其實非常簡單,該框架提供一個方法formValues,它的返回類型是一個NSDictionary,其中key就是XLFormRowDescriptor設(shè)置時的Tag??梢灾苯釉诳刂破髦姓{(diào)用該方法獲取表單值,上面的效果圖設(shè)置后的表單信息如下:

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

最新評論