index.js 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. const verify = require('../../utils/Check');
  2. Component({
  3. externalClasses: [],
  4. properties: {
  5. form: {
  6. type: Array
  7. },
  8. showAll: {
  9. type: Boolean,
  10. value: true
  11. }, //不显示必填项
  12. onConfirm: {
  13. type: Function
  14. },
  15. interrupt: {
  16. type: Function
  17. }, //打断处理,用于条件判断 把form返回到上个页面处理重新传入
  18. },
  19. data: {
  20. temporary: null, //route选择暂存选中项
  21. },
  22. options: {
  23. multipleSlots: true //允许使用多个slot
  24. },
  25. methods: {
  26. route(e) {
  27. const {
  28. item
  29. } = e.currentTarget.dataset;
  30. getApp().globalData.handleSelect = this.handleRoute.bind(this);
  31. wx.navigateTo({
  32. url: item.url + '?params=' + JSON.stringify(item.params) + item.query
  33. })
  34. this.setData({
  35. temporary: {
  36. item: item,
  37. index: this.data.form.findIndex(v => v.valueName == item.valueName)
  38. }
  39. })
  40. },
  41. /* 处理路由返回结果 */
  42. handleRoute(data) {
  43. let temporary = this.data.temporary;
  44. if (temporary.item.interrupt) {
  45. this.triggerEvent("interrupt", {
  46. data,
  47. form: this.data.form,
  48. temporary
  49. });
  50. } else {
  51. wx.navigateBack();
  52. this.setData({
  53. [`form[${temporary.index}].value`]: data.value
  54. });
  55. this.confirm()
  56. }
  57. },
  58. /* 改变值 */
  59. inputChange(e) {
  60. let item = e.target.dataset.item,
  61. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  62. value = e.detail;
  63. //开始校验 //校验规则 不填:不校验 "base":默认校验 "phone":手机号 "mail":邮箱 "正则表达式":以自定义内容为校验标准
  64. if (item.checking) {
  65. let reg = item.checking;
  66. switch (item.checking) {
  67. case 'base':
  68. value = verify.queryStr(value);
  69. break;
  70. case 'phone':
  71. reg = /^1(3[0-9]|4[01456879]|5[0-35-9]|6[2567]|7[0-8]|8[0-9]|9[0-35-9])\d{8}$/;
  72. this.setData({
  73. [`form[${index}].errMsg`]: !reg.test(value) ? '请输入正确11位手机号码' : ''
  74. });
  75. break;
  76. case 'mail':
  77. reg = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/;
  78. this.setData({
  79. [`form[${index}].errMsg`]: !reg.test(value) ? '请输入正确的邮箱格式' : ''
  80. });
  81. break;
  82. default:
  83. reg = new RegExp(reg);
  84. this.setData({
  85. [`form[${index}].errMsg`]: !reg.test(value) ? item.hint || '输入文本不符合条件!' : ''
  86. });
  87. break;
  88. };
  89. };
  90. this.setData({
  91. [`form[${index}].value`]: value,
  92. [`form[${index}].error`]: false,
  93. });
  94. if (!item.required && value == '') this.setData({
  95. [`form[${index}].errMsg`]: "",
  96. });
  97. this.confirm();
  98. },
  99. /* 单列选择器 */
  100. bindSelectorChange(e) {
  101. let {
  102. item,
  103. index
  104. } = e.target.dataset,
  105. value = e.detail.value;
  106. this.setData({
  107. [`form[${index}].value`]: item.range[value][item.rangeKey],
  108. [`form[${index}].rangeIndex`]: value,
  109. [`form[${index}].error`]: false,
  110. });
  111. if (item.interrupt) this.triggerEvent("interrupt", {
  112. data: this.data.form[index],
  113. form: this.data.form,
  114. temporary: {
  115. item,
  116. index,
  117. },
  118. result: item.range[value]
  119. });
  120. this.confirm();
  121. },
  122. /* 日期,时间 选择器 */
  123. bindDateChange(e) {
  124. let item = e.target.dataset.item,
  125. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  126. value = e.detail.value;
  127. this.setData({
  128. [`form[${index}].value`]: value,
  129. [`form[${index}].error`]: false,
  130. });
  131. if (item.interrupt) this.triggerEvent("interrupt", {
  132. data: this.data.form[index],
  133. form: this.data.form
  134. });
  135. this.confirm();
  136. },
  137. /* 时间范围选择器 */
  138. rangeDateChange(e) {
  139. let item = e.target.dataset.item,
  140. i = e.target.dataset.index,
  141. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  142. value = e.detail.value;
  143. this.setData({
  144. [`form[${index}].value[${i}]`]: value,
  145. [`form[${index}].error`]: false,
  146. });
  147. this.confirm();
  148. },
  149. /* 省市县 */
  150. bindRegionChange(e) {
  151. let item = e.currentTarget.dataset.item,
  152. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  153. value = e.detail.value;
  154. this.setData({
  155. [`form[${index}].value`]: value,
  156. [`form[${index}].error`]: false,
  157. });
  158. this.confirm();
  159. },
  160. toOptions(e) {
  161. const {
  162. item
  163. } = e.currentTarget.dataset;
  164. wx.navigateTo({
  165. url: '/packageA/options/index?data=' + JSON.stringify(item),
  166. })
  167. },
  168. /* 自定义选项 */
  169. setOption(item) {
  170. let i = this.data.form.findIndex(v => v.valueName == item.valueName);
  171. this.setData({
  172. [`form[${i}].value`]: item.value
  173. });
  174. this.confirm();
  175. },
  176. /* 是否完成必填项 */
  177. confirm() {
  178. this.triggerEvent("onConfirm", this.data.form.some(v => {
  179. if (v.type == "dateRange" && v.required) {
  180. return v.value[0] == "" || v.value[1] == "";
  181. } else {
  182. return v.required && v.value === '';
  183. }
  184. }));
  185. this.setData({
  186. temporary: null
  187. })
  188. },
  189. /* 性别 */
  190. sexChange(e) {
  191. let item = e.currentTarget.dataset.item,
  192. index = this.data.form.findIndex(v => v.valueName === item.valueName);
  193. this.setData({
  194. [`form[${index}].value`]: e.detail,
  195. [`form[${index}].error`]: false,
  196. });
  197. this.confirm();
  198. },
  199. /* 单选 选择器改变 */
  200. radioChange(e) {
  201. let item = e.currentTarget.dataset.item,
  202. index = this.data.form.findIndex(v => v.valueName == item.valueName);
  203. this.setData({
  204. [`form[${index}].value`]: e.detail,
  205. [`form[${index}].error`]: false,
  206. });
  207. if (item.interrupt) this.triggerEvent("interrupt", {
  208. data: this.data.form[index],
  209. form: this.data.form
  210. });
  211. this.confirm();
  212. },
  213. /* 提交 */
  214. submit() {
  215. let obj = {},
  216. isPass = false;
  217. this.data.form.forEach((v, i) => {
  218. obj[v.valueName] = v.value;
  219. if (v.errMsg != '') {
  220. this.setData({
  221. [`form[${i}].error`]: true
  222. });
  223. isPass = true;
  224. }
  225. });
  226. if (isPass) {
  227. wx.showToast({
  228. title: '请检查表单内容',
  229. icon: "none"
  230. })
  231. } else {
  232. return obj;
  233. }
  234. },
  235. /* 查询结果 不验证是否必填 */
  236. query() {
  237. let obj = {};
  238. this.data.form.forEach(v => {
  239. obj[v.valueName] = v.value;
  240. });
  241. return obj;
  242. }
  243. }
  244. })