最近做的app项目大量使用到表单填写,单独抽离出来做出封装以及遇到的问题
表单组件结构
EditHeader: 组件的枚举文件包括必填,各种cell的类型等
Cell : 不同类型的表单cell组件
Model : 包括表单提交时的apiModel和cell数据两个基类
构建表单过程
当需要构建一个表单时,需要准备下面的文件
plist文件用于构建表格需要显示的所有元素集合并且设置是否必填,apiKey(最终映射到apiModel上的字段名),正则限制,cell类型等等
继承apiModel的子类来定义不同的提交字段
继承viewModel的子类来自定义一些cell的处理
使用的时候只需要提取plist文件的数据初始化infoView就可以直接生成所需要的表单如果不需要自定义viewModel第3个文件可以省略当然最好还是写一个万一以后需求改了呢
数据回填
表单的数据回填肯定也会经常有这样的需求喽
如果表单回填只需要把要求回填的数据初始化给apiModel然后在用plist生成viewModel的时候调用
setValueAndTextWithApiModel方法进行数据回填,然后再初始化表单就可以,是不是非常的简单
提交数据
当用户填写完成后怎么提交数据
convertFromEditInfoViewModels此方法可以把infoView的viewModel数组重新生成apiModel的数据当点击提交事件的时候用此方法更新apiModel的数据既可
遇到的问题
目前看到些组件在表单上的表现很不错,大大简化了表单的生成,但是当出现新需求的时候出现了一些问题
-
当表单的显示需要控制的时候,比如选择某个表单元素后需要插入一些新的表单元素此时.plist文件就比较无力
目前项目的解决方案1.可以建两个.plist文件进行切换,2.在vc里进行控制对.plist文件生成的数据进行控制
目前的两个解决方案都不太满意准备想新的方案优化,但目前项目中些需求比较少延后中
-
需要收起展开的表单
目前的解决方案是在.plist里加入了新的cell并且把收起展开的表单元素加在childItem字段里进行嵌套来控制收起与展开
the end
可能表达不太清晰如果有新的想法可以一起交流