index.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. const verify = require('../../utils/deleteMark');
  2. Component({
  3. externalClasses: [],
  4. properties: {
  5. form: Array,
  6. showAll: {
  7. type: Boolean,
  8. value: true
  9. }, //不显示必填项
  10. onConfirm: Function
  11. },
  12. options: {
  13. multipleSlots: true //允许使用多个slot
  14. },
  15. methods: {
  16. toOptions(e) {
  17. const {
  18. item
  19. } = e.currentTarget.dataset;
  20. wx.navigateTo({
  21. url: '/packageA/options/index?data=' + JSON.stringify(item),
  22. })
  23. },
  24. /* 改变值 */
  25. inputChange(e) {
  26. let item = e.target.dataset.item,
  27. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  28. value = e.detail;
  29. //开始校验 //校验规则 不填:不校验 "base":默认校验 "phone":手机号 "mail":邮箱 "正则表达式":以自定义内容为校验标准
  30. if (item.checking) {
  31. let reg = item.checking;
  32. switch (item.checking) {
  33. case 'base':
  34. value = verify.queryStr(value);
  35. break;
  36. case 'phone':
  37. 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}$/;
  38. this.setData({
  39. [`form[${index}].errMsg`]: !reg.test(value) ? '请输入正确11位手机号码' : ''
  40. });
  41. break;
  42. case 'mail':
  43. reg = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/;
  44. this.setData({
  45. [`form[${index}].errMsg`]: !reg.test(value) ? '请输入正确的邮箱格式' : ''
  46. });
  47. break;
  48. default:
  49. reg = new RegExp(reg);
  50. this.setData({
  51. [`form[${index}].errMsg`]: !reg.test(value) ? '输入文本不符合条件!' : ''
  52. });
  53. break;
  54. };
  55. };
  56. this.setData({
  57. [`form[${index}].value`]: value,
  58. [`form[${index}].error`]: false,
  59. });
  60. if (!item.required && value == '') this.setData({
  61. [`form[${index}].errMsg`]: "",
  62. });
  63. this.confirm();
  64. },
  65. /* 日期,时间 选择器 */
  66. bindDateChange(e) {
  67. let item = e.target.dataset.item,
  68. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  69. value = e.detail.value;
  70. this.setData({
  71. [`form[${index}].value`]: value,
  72. [`form[${index}].error`]: false,
  73. });
  74. this.confirm();
  75. },
  76. /* 省市县 */
  77. bindRegionChange(e) {
  78. let item = e.currentTarget.dataset.item,
  79. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  80. value = e.detail.value;
  81. this.setData({
  82. [`form[${index}].value`]: value,
  83. [`form[${index}].error`]: false,
  84. });
  85. this.confirm();
  86. },
  87. /* 自定义选项 */
  88. setOption(item) {
  89. let i = this.data.form.findIndex(v => v.valueName == item.valueName);
  90. this.setData({
  91. [`form[${i}].value`]: item.value
  92. });
  93. this.confirm();
  94. },
  95. /* 是否完成必填项 */
  96. confirm() {
  97. this.triggerEvent("onConfirm", this.data.form.some(v => v.required && v.value == ''))
  98. },
  99. /* 性别 */
  100. sexChange(e) {
  101. let item = e.currentTarget.dataset.item,
  102. index = this.data.form.findIndex(v => v.valueName === item.valueName);
  103. this.setData({
  104. [`form[${index}].value`]: e.detail,
  105. [`form[${index}].error`]: false,
  106. });
  107. this.confirm();
  108. },
  109. /* 提交 */
  110. submit() {
  111. let obj = {},
  112. isPass = false;
  113. this.data.form.forEach((v, i) => {
  114. obj[v.valueName] = v.value;
  115. if (v.errMsg != '') {
  116. this.setData({
  117. [`form[${i}].error`]: true
  118. });
  119. isPass = true;
  120. }
  121. });
  122. if (isPass) {
  123. wx.showToast({
  124. title: '请检查表单内容',
  125. icon: "none"
  126. })
  127. } else {
  128. return obj;
  129. }
  130. },
  131. }
  132. })