iOS XLForm的使用

—、改造表單ViewController

讓ViewController繼承自XLFormViewController,并重寫下面的兩個(gè)方法

@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,一個(gè)表單只有一個(gè)
  XLFormSectionDescriptor * section;//section,一個(gè)表單可能有多個(gè)
  XLFormRowDescriptor * row; //row,每個(gè)section可能有多個(gè)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];

}

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

三、總結(jié)

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

  1. XLFormViewController實(shí)現(xiàn)了UITableViewDataSource, UITableViewDelegate,并且持有一個(gè)UITableView,這個(gè)從該類的聲明可以看出來,所以UITableView 、UITableViewDataSource, UITableViewDelegate中的方法都可以正常使用。
@interface XLFormViewController : UIViewController<UITableViewDataSource, UITableViewDelegate, XLFormDescriptorDelegate, UITextFieldDelegate, UITextViewDelegate, XLFormViewControllerDelegate>

  1. XLForm將表單抽象為Form,Section,Row三個(gè)層次,分別對(duì)應(yīng)三個(gè)類
XLFormDescriptor * form;//form,一個(gè)表單只有一個(gè)
XLFormSectionDescriptor * section;//section,一個(gè)表單可能有多個(gè)
XLFormRowDescriptor * row; //row,每個(gè)section可能有多個(gè)row

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

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

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

這個(gè)配置的時(shí)候,往往有同學(xué)不知道具體如何才能設(shè)置屬性,比如怎么設(shè)置表單輸入框的placeholder?更進(jìn)一步如何設(shè)置placeholder 的顏色。其實(shí)它用到了KVC,因?yàn)樗鼈儍蓚€(gè)都是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è)置好的表單的值?其實(shí)非常簡單,該框架提供一個(gè)方法formValues,它的返回類型是一個(gè)NSDictionary,其中key就是XLFormRowDescriptor設(shè)置時(shí)的Tag??梢灾苯釉诳刂破髦姓{(diào)用該方法獲取表單值,上面的效果圖設(shè)置后的表單信息如下:

    image
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 在iOS開發(fā)中,開發(fā)"表單"界面,字段稍微多一點(diǎn)的一般都用UITableView來做,而XLForm就是這樣一個(gè)框...
    YungFan閱讀 5,695評(píng)論 20 28
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對(duì)...
    cosWriter閱讀 11,689評(píng)論 1 32
  • XLForm 目的 XLForm是創(chuàng)建動(dòng)態(tài)表格視圖最靈活、最強(qiáng)大的iOS庫。 本庫的目的是像手動(dòng)創(chuàng)建一樣,實(shí)現(xiàn)表單...
    Mob_Developer閱讀 8,363評(píng)論 17 22
  • 七律-庭蘭莜莜 庭蘭莜莜雨瀟瀟, 幽徑彎彎靜悄悄。 鑿芷岸邊楊柳綠, 樂園場(chǎng)間杏花嬌。 雨敲芭葉叭叭叫, 云走朝南...
    詩者如斯夫閱讀 521評(píng)論 6 9
  • 順手翻看前幾日關(guān)注的江一燕的公眾號(hào),發(fā)現(xiàn)里面有個(gè)話題征集:1997年的時(shí)候你們都在干些什么?有什么有趣的事? 19...
    遇見燈芯草閱讀 484評(píng)論 0 1

友情鏈接更多精彩內(nèi)容