成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

iOS如何實(shí)現(xiàn)自定義表單-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)iOS如何實(shí)現(xiàn)自定義表單的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

創(chuàng)新互聯(lián)成立于2013年,先為中江等服務(wù)建站,中江等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為中江企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

前言

最近在開發(fā)一個(gè)APP,需要讓用戶填寫數(shù)據(jù),然后上傳到服務(wù)端進(jìn)行計(jì)算并返回結(jié)果在客戶端中展示。其中需要填寫的數(shù)據(jù)項(xiàng)多達(dá)十幾項(xiàng),大部分是必填。所有表單數(shù)據(jù)在一個(gè)頁面中實(shí)現(xiàn),在APP中這樣的設(shè)計(jì)其實(shí)挺逆天的,但產(chǎn)品經(jīng)理堅(jiān)持要這么弄,也只能硬著頭皮寫。頁面的表單數(shù)據(jù)樣式五花八門,下圖是其中幾行截圖

iOS如何實(shí)現(xiàn)自定義表單

第一、二行的 textfield 其實(shí)是一個(gè)選擇框,只能從下拉選項(xiàng)中選擇一個(gè)。第三個(gè)只允許輸入數(shù)字。

頁面由另一個(gè)同學(xué)實(shí)現(xiàn),表單的數(shù)據(jù)基本都在 cellForRowAtIndexPath 實(shí)現(xiàn),結(jié)果是這樣的:

iOS如何實(shí)現(xiàn)自定義表單

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

XLForm

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

XLForm 是最靈活且最強(qiáng)大的創(chuàng)建動態(tài)表單的iOS庫。更多的使用方法可以參考這篇文章:https://www.jb51.net/article/138943.htm

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

iOS如何實(shí)現(xiàn)自定義表單

最主要的是紅色方框的三個(gè)類:XLFormRowDescriptor, XLFormSectionDescriptor,XLFormDescriptor。XLFormDescriptor結(jié)構(gòu)和UITablView一樣,有Section,有Row,它就是為成為UITableView的數(shù)據(jù)源而設(shè)計(jì)的。XLFormRowDescriptor定義了每行表單的數(shù)據(jù)內(nèi)容,包括行樣式,標(biāo)題,行類型,選擇項(xiàng)內(nèi)容,標(biāo)簽,合法性驗(yàn)證等。XLFormSectionDescriptor是由XLFormRowDescriptor組合而成的,而XLFormSectionDescriptor最終又組成了XLFormDescriptor。

由于我們要實(shí)現(xiàn)的APP表單行樣式更復(fù)雜,有的一行要提交兩項(xiàng)數(shù)據(jù),所以需要對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;

這樣,表單數(shù)據(jù)就獨(dú)立于UI,TableViewCell是可配置的。通過XLFormRowDescriptor 來配置TableViewCell。只要指定行類型,就給出相應(yīng)的類型的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 怎么根據(jù)不同的行給出不同的cell?cell需要繼承同一個(gè)父類,這個(gè)父類足夠簡單,只有一個(gè)WWEFormRowDescriptor屬性,其它需要實(shí)現(xiàn)的方法則由WWECellProtocal負(fù)責(zé)。

@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

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

iOS如何實(shí)現(xiàn)自定義表單

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

iOS如何實(shí)現(xiàn)自定義表單

這樣上傳表單數(shù)據(jù)就無比輕松了,[self.form localValidationErrors]驗(yàn)證數(shù)據(jù)合法性,全部合法的話再調(diào)用[self.form httpParameters]就獲取了所有的表單數(shù)據(jù),傳給網(wǎng)絡(luò)接口就大功告成了。

感謝各位的閱讀!關(guān)于“iOS如何實(shí)現(xiàn)自定義表單”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站jinyejixie.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

文章名稱:iOS如何實(shí)現(xiàn)自定義表單-創(chuàng)新互聯(lián)
鏈接地址:http://jinyejixie.com/article2/hiiic.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供電子商務(wù)、網(wǎng)站策劃、微信小程序、定制網(wǎng)站、標(biāo)簽優(yōu)化網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計(jì)公司
增城市| 高淳县| 永德县| 望江县| 南郑县| 岳普湖县| 巴彦县| 铜陵市| 朝阳区| 岳普湖县| 霍城县| 黄平县| 五大连池市| 吉隆县| 巨野县| 铁岭县| 武威市| 晋宁县| 蓬莱市| 毕节市| 铁岭市| 舞钢市| 临泽县| 琼中| 祁门县| 平度市| 达日县| 赤城县| 阿巴嘎旗| 远安县| 高邮市| 新余市| 六安市| 尉氏县| 南康市| 赣榆县| 故城县| 河东区| 宣汉县| 博兴县| 清原|