亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS實現自定義表單實例代碼

2019-10-21 18:41:19
字體:
來源:轉載
供稿:網友

前言

最近在開發一個APP,需要讓用戶填寫數據,然后上傳到服務端進行計算并返回結果在客戶端中展示。其中需要填寫的數據項多達十幾項,大部分是必填。所有表單數據在一個頁面中實現,在APP中這樣的設計其實挺逆天的,但產品經理堅持要這么弄,也只能硬著頭皮寫。頁面的表單數據樣式五花八門,下圖是其中幾行截圖

ios,表單,實現表單提交form,自定義表單

第一、二行的 textfield 其實是一個選擇框,只能從下拉選項中選擇一個。第三個只允許輸入數字。

頁面由另一個同學實現,表單的數據基本都在 cellForRowAtIndexPath 實現,結果是這樣的:

ios,表單,實現表單提交form,自定義表單

看著這么多的if...else...一下子就凌亂了。讓我怎么接手實現網絡接口,上傳表單數據,難道也寫這么多的if...else...?這么實現之后要改其中某行數據的話,比如增加或刪除一行表單,就得改N個地方。這樣不僅浪費時間,而且容易出錯,要么改錯了要么沒改全。這樣的代碼后期維護成本太高,只能重寫了。那么問題來了,怎么改?從何開始?

XLForm

XLForm is the most flexible and powerful iOS library to create dynamic table-view forms. Fully compatible with Swift & Obj-C.

XLForm 是最靈活且最強大的創建動態表單的iOS庫。更多的使用方法可以參考這篇文章:http://www.49028c.com/article/138943.htm

以下是這個庫一個簡單的結構圖:

ios,表單,實現表單提交form,自定義表單

最主要的是紅色方框的三個類:XLFormRowDescriptor, XLFormSectionDescriptor,XLFormDescriptor。XLFormDescriptor結構和UITablView一樣,有Section,有Row,它就是為成為UITableView的數據源而設計的。XLFormRowDescriptor定義了每行表單的數據內容,包括行樣式,標題,行類型,選擇項內容,標簽,合法性驗證等。XLFormSectionDescriptor是由XLFormRowDescriptor組合而成的,而XLFormSectionDescriptor最終又組成了XLFormDescriptor。

由于我們要實現的APP表單行樣式更復雜,有的一行要提交兩項數據,所以需要對XLFormRowDescriptor做些改動。代碼如下:

@property (strong, nonatomic) NSMutableDictionary *cellConfig;@property (strong, nonatomic) NSDictionary *textFieldConfig;@property (strong, readonly, nonatomic) NSString *rowType;@property (strong, readonly, nonatomic) NSArray *leftOptions;@property (strong, readonly, nonatomic) WWEFormRightSelectorOption *rightOptions;@property (strong, nonatomic) NSString *title;@property (strong, nonatomic) id value;@property (strong, nonatomic) NSString *tag;@property (nonatomic) BOOL required;@property (strong, nonatomic) WWEBaseTableViewCell *tableViewCell;-(id)initWithRowType:(NSString *)rowType  title:(NSString *)title  leftOptions:(NSArray *)leftOptions rightOptions:(WWEFormRightSelectorOption *)rightOptions;-(WWEFormValidation *)doValidation;@end@interface WWEFormRightSelectorOption : NSObject@property (readonly, nonatomic) NSArray *rightOptions;@property (readonly, nonatomic) NSString *httpParameterKey;@property (readonly, nonatomic) NSString *selectorTitle;@property (nonatomic) NSInteger selectedIndex;+(WWEFormRightSelectorOption *)formRightSelectorOptionWithTitle:(NSString *)title      httpParameterKey:(NSString *)httpParameterKey      rightOptions:(NSArray *)rightOptions;

這樣,表單數據就獨立于UI,TableViewCell是可配置的。通過XLFormRowDescriptor 來配置TableViewCell。只要指定行類型,就給出相應的類型的Cell。TableViewController中的Cell是由XLFormRowDescriptor提供的。

- (WWEBaseTableViewCell *)tableViewCell { if (!_tableViewCell) { id cellClass = [self cellClassesForRowDescriptorTypes][self.rowType]; NSAssert(cellClass, @"Not defined XLFormRowDescriptorType: %@", self.rowType ?: @"");  _tableViewCell = [[cellClass alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:nil];  NSAssert([_tableViewCell isKindOfClass:[WWEBaseTableViewCell class]], @"UITableViewCell must extend from WWEBaseTableViewCell"); _tableViewCell.rowDescriptor = self; } return _tableViewCell;}

那么 XLFormRowDescriptor 怎么根據不同的行給出不同的cell?cell需要繼承同一個父類,這個父類足夠簡單,只有一個WWEFormRowDescriptor屬性,其它需要實現的方法則由WWECellProtocal負責。

@class WWEFormRowDescriptor;@interface WWEBaseTableViewCell : UITableViewCell<WWECellProtocal>@property (nonatomic, weak) WWEFormRowDescriptor *rowDescriptor;@end
@class WWEFormRowDescriptor;@protocol WWECellProtocal <NSObject>@required@property (nonatomic, weak) WWEFormRowDescriptor *rowDescriptor;-(void)configure;-(void)update;@end

另外,將表單配置數據獨立出來,而不是寫死在代碼中。使用plist文件,這樣初始化form時只需讀取這個文件,就完成了cell的配置。后續如果要改動表單的內容,不改動樣式,就只需修改plist文件,而無需改動代碼。

ios,表單,實現表單提交form,自定義表單

最后TableViewController的代碼就格外簡單了:

ios,表單,實現表單提交form,自定義表單

這樣上傳表單數據就無比輕松了, [self.form localValidationErrors] 驗證數據合法性,全部合法的話再調用 [self.form httpParameters] 就獲取了所有的表單數據,傳給網絡接口就大功告成了。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产亚洲精品91在线| 欧美一级大片在线免费观看| 亚洲一区二区三区在线视频| 国产精品久久久久aaaa九色| 欧美中文字幕第一页| 免费不卡欧美自拍视频| 日韩精品在线播放| 国产一区二区在线免费视频| 欧洲美女免费图片一区| 2025国产精品视频| 日韩欧美亚洲成人| 亚洲一区二区久久久久久久| 福利精品视频在线| 久久99国产精品自在自在app| 91视频88av| 在线日韩av观看| 欧美高清电影在线看| 69久久夜色精品国产69| 一色桃子一区二区| 亚洲欧洲在线播放| 欧美激情视频一区二区三区不卡| 国产精品电影久久久久电影网| 精品日本美女福利在线观看| 久久天天躁夜夜躁狠狠躁2022| 97色在线观看免费视频| 欧美极品少妇xxxxⅹ免费视频| 国产丝袜一区二区三区免费视频| 精品美女久久久久久免费| 午夜精品一区二区三区在线播放| 精品日韩视频在线观看| 日韩成人在线视频网站| 亚洲成**性毛茸茸| 日本国产一区二区三区| 亚洲欧洲午夜一线一品| 久久成人这里只有精品| 欧美精品一区二区三区国产精品| 亚洲一区二区三区sesese| 亚洲精品久久久久久久久久久久| 国产噜噜噜噜噜久久久久久久久| 国产精品在线看| 97香蕉超级碰碰久久免费软件| 91产国在线观看动作片喷水| 亚洲欧美在线磁力| 国产精品自产拍在线观| 青草青草久热精品视频在线网站| 日韩av手机在线看| 欧美日韩免费区域视频在线观看| 青草热久免费精品视频| 亚洲一区二区久久久久久久| 57pao精品| 俺去了亚洲欧美日韩| 姬川优奈aav一区二区| 国产亚洲一级高清| 亚洲少妇激情视频| 日韩中文有码在线视频| 永久555www成人免费| 国产成人jvid在线播放| 色综合久久天天综线观看| 亚洲综合精品伊人久久| 成人性生交大片免费观看嘿嘿视频| 狠狠躁天天躁日日躁欧美| 亚洲丝袜一区在线| 亚洲 日韩 国产第一| 精品久久久久久电影| 91精品国产亚洲| 97超视频免费观看| 久久99国产精品久久久久久久久| www.亚洲成人| 欧美精品一区三区| 国产精品视频一区二区高潮| 国产精品第二页| 久国内精品在线| 欧美激情三级免费| 91av在线看| 国产欧美精品久久久| 精品久久久久久久中文字幕| 国产精品夜色7777狼人| 91国内免费在线视频| 奇米影视亚洲狠狠色| 国模精品系列视频| 亚洲免费成人av电影| 亚洲免费高清视频| 日韩在线激情视频| 国产噜噜噜噜久久久久久久久| 欧美一级电影在线| 国产精品视频导航| 亚洲香蕉成人av网站在线观看| 日韩电影中文字幕av| 最新91在线视频| 成人高清视频观看www| 777精品视频| 九九热精品在线| 欧美最顶级丰满的aⅴ艳星| 2019中文字幕在线| 青青精品视频播放| 久久精品成人欧美大片| 亚洲国产精品久久久久久| 亚洲精品ady| 国产精品尤物福利片在线观看| 成人午夜一级二级三级| 亚洲美女免费精品视频在线观看| 国产成人精品av在线| www.午夜精品| 久久久天堂国产精品女人| 菠萝蜜影院一区二区免费| 亚洲第一精品电影| 亚洲最新在线视频| 九九热这里只有精品免费看| 欧美制服第一页| 亚洲国产精品成人va在线观看| 色综合久久88| 欧美成人自拍视频| 日本久久久久久久久| 久久91精品国产91久久跳| 欧美人成在线视频| 亚洲国产精品久久久久| 中文字幕精品在线视频| 色妞欧美日韩在线| 国产欧美精品一区二区三区-老狼| 国产一区二区三区在线看| 国产精品久久久久久久天堂| 浅井舞香一区二区| 成人免费午夜电影| 日韩的一区二区| 91精品久久久久久久久| 久久久之久亚州精品露出| 亚洲免费视频观看| 91国产精品视频在线| 91成人在线观看国产| 成人黄色大片在线免费观看| 国产精品一二三视频| 国产精品日韩欧美大师| 日韩的一区二区| 国产日韩换脸av一区在线观看| 成人免费看片视频| 日韩电视剧在线观看免费网站| 亚洲二区在线播放视频| 欧美国产日韩在线| 亚洲精品网址在线观看| 亚洲欧美国产另类| 日韩欧美高清在线视频| 在线日韩av观看| 久久久久久亚洲精品中文字幕| 欧美激情精品久久久久久大尺度| 欧美激情视频网站| 最近2019中文字幕一页二页| 国产在线拍偷自揄拍精品| 91视频-88av| 国产成人激情小视频| 97人人做人人爱| 亚洲视频在线播放| 日韩影视在线观看| 日韩在线免费视频| 亚洲曰本av电影| 日本精品视频网站| 国产精品欧美激情在线播放| 精品久久中文字幕久久av| 国产精品色悠悠| 97久久久久久| 在线观看亚洲区| 欧美在线国产精品| 国产在线拍偷自揄拍精品| 国产精品中文久久久久久久| 国产精品久久久久久久久久|