iOS表单组件封装小结

最近做的app项目大量使用到表单填写,单独抽离出来做出封装以及遇到的问题

表单组件结构

image

EditHeader: 组件的枚举文件包括必填,各种cell的类型等

Cell : 不同类型的表单cell组件

Model : 包括表单提交时的apiModel和cell数据两个基类

构建表单过程


当需要构建一个表单时,需要准备下面的文件

  1. plist文件用于构建表格需要显示的所有元素集合并且设置是否必填,apiKey(最终映射到apiModel上的字段名),正则限制,cell类型等等

  2. 继承apiModel的子类来定义不同的提交字段

  3. 继承viewModel的子类来自定义一些cell的处理

使用的时候只需要提取plist文件的数据初始化infoView就可以直接生成所需要的表单如果不需要自定义viewModel第3个文件可以省略当然最好还是写一个万一以后需求改了呢

数据回填

表单的数据回填肯定也会经常有这样的需求喽

如果表单回填只需要把要求回填的数据初始化给apiModel然后在用plist生成viewModel的时候调用

setValueAndTextWithApiModel方法进行数据回填,然后再初始化表单就可以,是不是非常的简单

提交数据

当用户填写完成后怎么提交数据

convertFromEditInfoViewModels此方法可以把infoView的viewModel数组重新生成apiModel的数据当点击提交事件的时候用此方法更新apiModel的数据既可

遇到的问题

目前看到些组件在表单上的表现很不错,大大简化了表单的生成,但是当出现新需求的时候出现了一些问题

  1. 当表单的显示需要控制的时候,比如选择某个表单元素后需要插入一些新的表单元素此时.plist文件就比较无力

    目前项目的解决方案1.可以建两个.plist文件进行切换,2.在vc里进行控制对.plist文件生成的数据进行控制

    目前的两个解决方案都不太满意准备想新的方案优化,但目前项目中些需求比较少延后中

  2. 需要收起展开的表单

    目前的解决方案是在.plist里加入了新的cell并且把收起展开的表单元素加在childItem字段里进行嵌套来控制收起与展开

the end

可能表达不太清晰如果有新的想法可以一起交流

你可能感兴趣的:(iOS表单组件封装小结)