index.js 6.0 KB

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