index.js 7.2 KB

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