eoss-ui 0.5.58 → 0.5.60

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (75) hide show
  1. package/lib/button-group.js +52 -11
  2. package/lib/button.js +39 -0
  3. package/lib/calendar.js +42 -14
  4. package/lib/card.js +186 -186
  5. package/lib/checkbox-group.js +39 -0
  6. package/lib/data-table-form.js +39 -0
  7. package/lib/data-table.js +39 -0
  8. package/lib/date-picker.js +39 -0
  9. package/lib/dialog.js +39 -0
  10. package/lib/eoss-ui.common.js +1290 -392
  11. package/lib/flow-group.js +39 -0
  12. package/lib/flow-list.js +39 -0
  13. package/lib/flow.js +42 -4
  14. package/lib/form.js +717 -18
  15. package/lib/handle-user.js +39 -0
  16. package/lib/handler.js +39 -0
  17. package/lib/icon.js +39 -0
  18. package/lib/index.js +1 -1
  19. package/lib/input-number.js +39 -0
  20. package/lib/input.js +39 -0
  21. package/lib/login.js +45 -6
  22. package/lib/main.js +39 -0
  23. package/lib/nav.js +39 -0
  24. package/lib/page.js +39 -0
  25. package/lib/player.js +39 -0
  26. package/lib/qr-code.js +39 -0
  27. package/lib/radio-group.js +39 -0
  28. package/lib/retrial-auth.js +39 -0
  29. package/lib/select-ganged.js +39 -0
  30. package/lib/select.js +39 -0
  31. package/lib/selector-panel.js +39 -0
  32. package/lib/selector.js +39 -0
  33. package/lib/sizer.js +39 -0
  34. package/lib/steps.js +39 -0
  35. package/lib/switch.js +39 -0
  36. package/lib/table-form.js +214 -5
  37. package/lib/tabs.js +39 -0
  38. package/lib/theme-chalk/base.css +1 -1
  39. package/lib/theme-chalk/card.css +1 -1
  40. package/lib/theme-chalk/cascader.css +1 -1
  41. package/lib/theme-chalk/icon.css +1 -1
  42. package/lib/theme-chalk/index.css +1 -1
  43. package/lib/theme-chalk/main.css +1 -1
  44. package/lib/theme-chalk/menu.css +1 -1
  45. package/lib/theme-chalk/sizer.css +1 -1
  46. package/lib/theme-chalk/upload.css +1 -1
  47. package/lib/tips.js +39 -0
  48. package/lib/tree-group.js +39 -0
  49. package/lib/tree.js +39 -0
  50. package/lib/upload.js +39 -0
  51. package/lib/utils/util.js +39 -0
  52. package/lib/wujie.js +39 -0
  53. package/lib/wxlogin.js +39 -0
  54. package/package.json +2 -2
  55. package/packages/button-group/src/main.vue +16 -11
  56. package/packages/calendar/src/main.vue +25 -6
  57. package/packages/card/src/main.vue +72 -60
  58. package/packages/flow/src/main.vue +1 -2
  59. package/packages/form/src/main.vue +129 -0
  60. package/packages/form/src/table.vue +33 -0
  61. package/packages/login/src/main.vue +6 -4
  62. package/packages/theme-chalk/lib/base.css +1 -1
  63. package/packages/theme-chalk/lib/card.css +1 -1
  64. package/packages/theme-chalk/lib/cascader.css +1 -1
  65. package/packages/theme-chalk/lib/icon.css +1 -1
  66. package/packages/theme-chalk/lib/index.css +1 -1
  67. package/packages/theme-chalk/lib/main.css +1 -1
  68. package/packages/theme-chalk/lib/menu.css +1 -1
  69. package/packages/theme-chalk/lib/sizer.css +1 -1
  70. package/packages/theme-chalk/lib/upload.css +1 -1
  71. package/packages/theme-chalk/src/card.scss +63 -22
  72. package/packages/theme-chalk/src/cascader.scss +21 -5
  73. package/packages/theme-chalk/src/icon.scss +0 -1
  74. package/src/index.js +1 -1
  75. package/src/utils/util.js +37 -0
package/lib/wxlogin.js CHANGED
@@ -1974,7 +1974,45 @@ var indexOfObj = function indexOfObj(arry, target, key) {
1974
1974
  }
1975
1975
  return -1;
1976
1976
  };
1977
+ /**
1978
+ * isEmpty
1979
+ * @desc:判断是否为空
1980
+ * @author huangbo
1981
+ * @date 2022年5月7日
1982
+ * @param {Object} [obj] -
1983
+ **/
1984
+ var isEmpty = function isEmpty(val) {
1985
+ // null or undefined
1986
+ if (val === null || val === undefined) return true;
1987
+
1988
+ if (typeof val === 'boolean') return false;
1989
+
1990
+ if (typeof val === 'number') return !val;
1991
+
1992
+ if (val instanceof Error) return val.message === '';
1977
1993
 
1994
+ switch (Object.prototype.toString.call(val)) {
1995
+ // String or Array
1996
+ case '[object String]':
1997
+ case '[object Array]':
1998
+ return !val.length;
1999
+
2000
+ // Map or Set or File
2001
+ case '[object File]':
2002
+ case '[object Map]':
2003
+ case '[object Set]':
2004
+ {
2005
+ return !val.size;
2006
+ }
2007
+ // Plain Object
2008
+ case '[object Object]':
2009
+ {
2010
+ return !Object.keys(val).length;
2011
+ }
2012
+ }
2013
+
2014
+ return false;
2015
+ };
1978
2016
  /**
1979
2017
  * isExist
1980
2018
  * @desc:判断是否存在
@@ -3055,6 +3093,7 @@ var watermark = function watermark(option) {
3055
3093
  hsvTorgb: hsvTorgb,
3056
3094
  identical: identical,
3057
3095
  indexOfObj: indexOfObj,
3096
+ isEmpty: isEmpty,
3058
3097
  isExist: isExist,
3059
3098
  isFunction: isFunction,
3060
3099
  isLogged: isLogged,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "eoss-ui",
3
- "version": "0.5.58",
3
+ "version": "0.5.60",
4
4
  "description": "eoss内部业务组件",
5
5
  "main": "lib/eoss-ui.common.js",
6
6
  "files": [
@@ -96,7 +96,7 @@
96
96
  "cp-cli": "^1.0.2",
97
97
  "cross-env": "^3.1.3",
98
98
  "css-loader": "^2.1.0",
99
- "eoss-element": "^0.2.89",
99
+ "eoss-element": "^0.2.91",
100
100
  "es6-promise": "^4.0.5",
101
101
  "eslint": "4.18.2",
102
102
  "eslint-config-elemefe": "0.1.1",
@@ -62,7 +62,8 @@ export default {
62
62
  trigger: {
63
63
  type: String,
64
64
  default: 'click'
65
- }
65
+ },
66
+ useCaseCodeKey: String
66
67
  },
67
68
  computed: {
68
69
  btns() {
@@ -86,27 +87,31 @@ export default {
86
87
  methods: {
87
88
  getBtns() {
88
89
  let useCaseCodes = util.getStorage('useCaseCodes');
90
+ let keyword =
91
+ this.data && this.useCaseCodeKey
92
+ ? this.data.row[this.useCaseCodeKey]
93
+ : null;
89
94
  let arry = this.contents.filter((item) => {
90
95
  if (Object.prototype.hasOwnProperty.call(item, 'rules')) {
91
- if (useCaseCodes && item.useCaseCode) {
96
+ if (useCaseCodes && (item.useCaseCode || keyword)) {
92
97
  return (
93
- item.rules(this.data) &&
94
- useCaseCodes.indexOf(item.useCaseCode) > -1
98
+ item.rules(this.data.row) &&
99
+ useCaseCodes.indexOf(item.useCaseCode || keyword) > -1
95
100
  );
96
101
  }
97
- return item.rules(this.data);
102
+ return item.rules(this.data.row);
98
103
  }
99
104
  if (this.rules !== undefined) {
100
- if (useCaseCodes && item.useCaseCode) {
105
+ if (useCaseCodes && (item.useCaseCode || keyword)) {
101
106
  return (
102
- this.rules(this.data) &&
103
- useCaseCodes.indexOf(item.useCaseCode) > -1
107
+ this.rules(this.data.row) &&
108
+ useCaseCodes.indexOf(item.useCaseCode || keyword) > -1
104
109
  );
105
110
  }
106
- return this.rules(this.data);
111
+ return this.rules(this.data.row);
107
112
  }
108
- if (useCaseCodes && item.useCaseCode) {
109
- return useCaseCodes.indexOf(item.useCaseCode) > -1;
113
+ if (useCaseCodes && (item.useCaseCode || keyword)) {
114
+ return useCaseCodes.indexOf(item.useCaseCode || keyword) > -1;
110
115
  }
111
116
  return true;
112
117
  });
@@ -2,9 +2,17 @@
2
2
  <div class="es-calendar">
3
3
  <div class="es-calendar-title" v-show="showTitle">
4
4
  <i class="es-calendar-prev es-icon-pointer-left" @click="prev"></i>
5
- <div class="es-title" @click="resetDate">
5
+ <div class="es-title">
6
6
  <slot name="title" :year="year" :month="month">
7
- {{ year }}年{{ month }}月
7
+ <es-date-picker
8
+ class="es-calendar-picker"
9
+ v-model="value"
10
+ type="month"
11
+ placeholder="选择日期时间"
12
+ format="yyyy年M月"
13
+ @change="handleChange"
14
+ >
15
+ </es-date-picker>
8
16
  </slot>
9
17
  </div>
10
18
  <i class="es-calendar-next es-icon-pointer-right" @click="next"></i>
@@ -111,8 +119,9 @@ export default {
111
119
  },
112
120
  data() {
113
121
  return {
122
+ value: '',
114
123
  year: '',
115
- _month: '',
124
+ month: '',
116
125
  weeks: ['日', '一', '二', '三', '四', '五', '六'],
117
126
  weekDate: [],
118
127
  week7: '',
@@ -158,9 +167,10 @@ export default {
158
167
  this.daysList = daysList;
159
168
  this.year = year;
160
169
  this.month = month;
161
- if (!this.weekDate.length) {
162
- this.weekDate = weekDate;
163
- }
170
+ this.value = `${year}年${month}月`;
171
+ //if (!this.weekDate.length) {
172
+ this.weekDate = weekDate;
173
+ //}
164
174
  this.$emit('init', dates);
165
175
  return dates;
166
176
  },
@@ -237,6 +247,15 @@ export default {
237
247
  let res = this.init(`${year}/${month}/${date}`);
238
248
  this.$emit('next', res, 'month');
239
249
  },
250
+ handleChange(val) {
251
+ let dates = val.replace('月', '').split('年');
252
+ let year = dates[0];
253
+ let month = dates[1];
254
+ month = month.padStart(2, '0');
255
+ let date = '01';
256
+ let res = this.init(`${year}/${month}/${date}`);
257
+ this.$emit('change', res);
258
+ },
240
259
  //获取当月或指定日期所在月天数
241
260
  getDays(res) {
242
261
  const date = res ? new Date(res) : new Date();
@@ -1,28 +1,65 @@
1
1
  <template>
2
- <el-card class="es-card" v-bind="$attrs">
2
+ <el-card
3
+ class="es-card"
4
+ :class="{ 'es-card-border-none': !border }"
5
+ v-bind="$attrs"
6
+ >
3
7
  <template slot="header">
4
- <div
5
- class="es-card-header"
6
- :class="{ 'es-card-ornament-hide': !show }"
7
- v-if="header || tabs"
8
- >
9
- <template v-if="header">
10
- <template v-if="isObject">
11
- <i
12
- v-if="header.icon"
13
- class="es-header-icon"
14
- :class="header.icon"
15
- ></i>
16
- <span v-if="header.text" class="es-header-text">{{
17
- header.text
18
- }}</span>
19
- <i
20
- v-if="header.icons"
21
- class="es-header-icons"
22
- :class="header.icons"
23
- ></i>
8
+ <div class="es-card-header" :class="modeClass">
9
+ <slot name="header">
10
+ <template v-if="header">
11
+ <template v-if="isObject">
12
+ <i
13
+ v-if="header.icon"
14
+ class="es-header-icon"
15
+ :class="header.icon"
16
+ ></i>
17
+ <span v-if="header.text" class="es-header-text">{{
18
+ header.text
19
+ }}</span>
20
+ <i
21
+ v-if="header.icons"
22
+ class="es-header-icons"
23
+ :class="header.icons"
24
+ ></i>
25
+ <el-menu
26
+ v-if="header.tabs"
27
+ slot="suffix"
28
+ class="es-card-menu"
29
+ mode="horizontal"
30
+ :default-active="active"
31
+ @select="handleSelect"
32
+ >
33
+ <template v-for="(item, index) in tabs">
34
+ <el-menu-item
35
+ v-if="typeof item === 'string'"
36
+ :key="index"
37
+ :index="String(index)"
38
+ >
39
+ {{ item }}
40
+ </el-menu-item>
41
+ <el-menu-item
42
+ v-else
43
+ :key="index"
44
+ :index="item.id ? item.id : String(index)"
45
+ >
46
+ <el-badge
47
+ :value="item.tips"
48
+ :max="max"
49
+ :is-dot="isDot"
50
+ :hidden="!item.tips || item.tips == '0'"
51
+ >
52
+ {{ item.name || item.label }}
53
+ </el-badge>
54
+ </el-menu-item>
55
+ </template>
56
+ </el-menu>
57
+ </template>
58
+ <span v-else class="es-header-text">{{ header }}</span>
59
+ </template>
60
+ <template>
24
61
  <el-menu
25
- v-if="header.tabs"
62
+ v-if="tabs"
26
63
  slot="suffix"
27
64
  class="es-card-menu"
28
65
  mode="horizontal"
@@ -54,45 +91,9 @@
54
91
  </template>
55
92
  </el-menu>
56
93
  </template>
57
- <span v-else class="es-header-text">{{ header }}</span>
58
- </template>
59
- <template>
60
- <el-menu
61
- v-if="tabs"
62
- slot="suffix"
63
- class="es-card-menu"
64
- mode="horizontal"
65
- :default-active="active"
66
- @select="handleSelect"
67
- >
68
- <template v-for="(item, index) in tabs">
69
- <el-menu-item
70
- v-if="typeof item === 'string'"
71
- :key="index"
72
- :index="String(index)"
73
- >
74
- {{ item }}
75
- </el-menu-item>
76
- <el-menu-item
77
- v-else
78
- :key="index"
79
- :index="item.id ? item.id : String(index)"
80
- >
81
- <el-badge
82
- :value="item.tips"
83
- :max="max"
84
- :is-dot="isDot"
85
- :hidden="!item.tips || item.tips == '0'"
86
- >
87
- {{ item.name || item.label }}
88
- </el-badge>
89
- </el-menu-item>
90
- </template>
91
- </el-menu>
92
- </template>
93
- <slot name="suffix"></slot>
94
+ <slot name="suffix"></slot>
95
+ </slot>
94
96
  </div>
95
- <slot v-else name="header"></slot>
96
97
  </template>
97
98
  <slot></slot>
98
99
  </el-card>
@@ -106,6 +107,14 @@ export default {
106
107
  type: Boolean,
107
108
  default: true
108
109
  },
110
+ mode: {
111
+ type: String,
112
+ default: 'bar'
113
+ },
114
+ border: {
115
+ type: Boolean,
116
+ default: true
117
+ },
109
118
  header: [String, Object],
110
119
  tabs: Array,
111
120
  defaultActive: String,
@@ -130,6 +139,9 @@ export default {
130
139
  }
131
140
  return this.defaultActive;
132
141
  }
142
+ },
143
+ modeClass() {
144
+ return this.show ? `es-card-ornament-${this.mode}` : '';
133
145
  }
134
146
  },
135
147
  data() {
@@ -1335,9 +1335,8 @@ export default {
1335
1335
  if(!this.$refs.commonOpinions.validate()) return
1336
1336
  }
1337
1337
  if (this.beforeSubmit != undefined) {
1338
- this.beforeSubmit()
1338
+ this.beforeSubmit(0)
1339
1339
  .then((next) => {
1340
-
1341
1340
  this.showReject = true;
1342
1341
  })
1343
1342
  .catch((e) => {});
@@ -587,6 +587,14 @@
587
587
  }
588
588
  "
589
589
  ></es-icons>
590
+ <component
591
+ v-else-if="item.type === 'component'"
592
+ v-model="models[item.name]"
593
+ v-bind="
594
+ handleExclAttribute({ data: item, attrs: ['value'] })
595
+ "
596
+ v-on="item.events"
597
+ ></component>
590
598
  <es-input
591
599
  v-else
592
600
  v-bind="
@@ -831,6 +839,17 @@
831
839
  }
832
840
  "
833
841
  ></es-icons>
842
+ <component
843
+ v-else-if="inline.type === 'component'"
844
+ v-model="models[inline.name]"
845
+ v-bind="
846
+ handleExclAttribute({
847
+ data: inline,
848
+ attrs: ['value']
849
+ })
850
+ "
851
+ v-on="inline.events"
852
+ ></component>
834
853
  <es-input
835
854
  v-else
836
855
  v-bind="
@@ -1068,6 +1087,17 @@
1068
1087
  }
1069
1088
  "
1070
1089
  ></es-icons>
1090
+ <component
1091
+ v-else-if="inline.type === 'component'"
1092
+ v-model="models[inline.name]"
1093
+ v-bind="
1094
+ handleExclAttribute({
1095
+ data: inline,
1096
+ attrs: ['value']
1097
+ })
1098
+ "
1099
+ v-on="inline.events"
1100
+ ></component>
1071
1101
  <es-input
1072
1102
  v-else
1073
1103
  v-bind="
@@ -1513,6 +1543,17 @@
1513
1543
  }
1514
1544
  "
1515
1545
  ></es-icons>
1546
+ <component
1547
+ v-else-if="item.type === 'component'"
1548
+ v-model="models[item.name]"
1549
+ v-bind="
1550
+ handleExclAttribute({
1551
+ data: item,
1552
+ attrs: ['value']
1553
+ })
1554
+ "
1555
+ v-on="item.events"
1556
+ ></component>
1516
1557
  <es-input
1517
1558
  v-else
1518
1559
  v-bind="
@@ -1729,6 +1770,17 @@
1729
1770
  }
1730
1771
  "
1731
1772
  ></es-icons>
1773
+ <component
1774
+ v-else-if="inline.type === 'component'"
1775
+ v-model="models[inline.name]"
1776
+ v-bind="
1777
+ handleExclAttribute({
1778
+ data: inline,
1779
+ attrs: ['value']
1780
+ })
1781
+ "
1782
+ v-on="inline.events"
1783
+ ></component>
1732
1784
  <es-input
1733
1785
  v-else
1734
1786
  v-bind="
@@ -1925,6 +1977,17 @@
1925
1977
  }
1926
1978
  "
1927
1979
  ></es-icons>
1980
+ <component
1981
+ v-else-if="item.inline.type === 'component'"
1982
+ v-model="models[item.inline.name]"
1983
+ v-bind="
1984
+ handleExclAttribute({
1985
+ data: item.inline,
1986
+ attrs: ['value']
1987
+ })
1988
+ "
1989
+ v-on="item.inline.events"
1990
+ ></component>
1928
1991
  <es-input
1929
1992
  v-else
1930
1993
  v-bind="
@@ -2485,6 +2548,17 @@
2485
2548
  }
2486
2549
  "
2487
2550
  ></es-icons>
2551
+ <component
2552
+ v-else-if="item.type === 'component'"
2553
+ v-model="models[item.name]"
2554
+ v-bind="
2555
+ handleExclAttribute({
2556
+ data: item,
2557
+ attrs: ['value']
2558
+ })
2559
+ "
2560
+ v-on="item.events"
2561
+ ></component>
2488
2562
  <es-input
2489
2563
  v-else
2490
2564
  v-bind="
@@ -2725,6 +2799,17 @@
2725
2799
  }
2726
2800
  "
2727
2801
  ></es-icons>
2802
+ <component
2803
+ v-else-if="inline.type === 'component'"
2804
+ v-model="models[inline.name]"
2805
+ v-bind="
2806
+ handleExclAttribute({
2807
+ data: inline,
2808
+ attrs: ['value']
2809
+ })
2810
+ "
2811
+ v-on="inline.events"
2812
+ ></component>
2728
2813
  <es-input
2729
2814
  v-else
2730
2815
  v-bind="
@@ -2943,6 +3028,17 @@
2943
3028
  }
2944
3029
  "
2945
3030
  ></es-icons>
3031
+ <component
3032
+ v-else-if="item.inline.type === 'component'"
3033
+ v-model="models[item.inline.name]"
3034
+ v-bind="
3035
+ handleExclAttribute({
3036
+ data: item.inline,
3037
+ attrs: ['value']
3038
+ })
3039
+ "
3040
+ v-on="item.inline.events"
3041
+ ></component>
2946
3042
  <es-input
2947
3043
  v-else
2948
3044
  v-bind="
@@ -3366,6 +3462,17 @@
3366
3462
  }
3367
3463
  "
3368
3464
  ></es-icons>
3465
+ <component
3466
+ v-else-if="item.type === 'component'"
3467
+ v-model="models[item.name]"
3468
+ v-bind="
3469
+ handleExclAttribute({
3470
+ data: item,
3471
+ attrs: ['value']
3472
+ })
3473
+ "
3474
+ v-on="item.events"
3475
+ ></component>
3369
3476
  <es-input
3370
3477
  v-else
3371
3478
  v-bind="handleExclAttribute({ data: item, attrs: ['value'] })"
@@ -3598,6 +3705,17 @@
3598
3705
  }
3599
3706
  "
3600
3707
  ></es-icons>
3708
+ <component
3709
+ v-else-if="inline.type === 'component'"
3710
+ v-model="models[inline.name]"
3711
+ v-bind="
3712
+ handleExclAttribute({
3713
+ data: inline,
3714
+ attrs: ['value']
3715
+ })
3716
+ "
3717
+ v-on="inline.events"
3718
+ ></component>
3601
3719
  <es-input
3602
3720
  v-else
3603
3721
  v-bind="
@@ -3794,6 +3912,17 @@
3794
3912
  }
3795
3913
  "
3796
3914
  ></es-icons>
3915
+ <component
3916
+ v-else-if="item.inline.type === 'component'"
3917
+ v-model="models[item.inline.name]"
3918
+ v-bind="
3919
+ handleExclAttribute({
3920
+ data: item.inline,
3921
+ attrs: ['value']
3922
+ })
3923
+ "
3924
+ v-on="item.inline.events"
3925
+ ></component>
3797
3926
  <es-input
3798
3927
  v-else
3799
3928
  v-bind="
@@ -431,6 +431,17 @@
431
431
  }
432
432
  "
433
433
  ></es-icons>
434
+ <component
435
+ v-else-if="item.type === 'component'"
436
+ v-model="models[item.name]"
437
+ v-bind="
438
+ handleExclAttribute({
439
+ data: item,
440
+ attrs: ['value']
441
+ })
442
+ "
443
+ v-on="item.events"
444
+ ></component>
434
445
  <es-input
435
446
  v-else
436
447
  v-bind="
@@ -707,6 +718,17 @@
707
718
  }
708
719
  "
709
720
  ></es-icons>
721
+ <component
722
+ v-else-if="inline.type === 'component'"
723
+ v-model="models[inline.name]"
724
+ v-bind="
725
+ handleExclAttribute({
726
+ data: inline,
727
+ attrs: ['value']
728
+ })
729
+ "
730
+ v-on="inline.events"
731
+ ></component>
710
732
  <es-input
711
733
  v-else
712
734
  v-bind="
@@ -915,6 +937,17 @@
915
937
  }
916
938
  "
917
939
  ></es-icons>
940
+ <component
941
+ v-else-if="item.inline.type === 'component'"
942
+ v-model="models[item.inline.name]"
943
+ v-bind="
944
+ handleExclAttribute({
945
+ data: item.inline,
946
+ attrs: ['value']
947
+ })
948
+ "
949
+ v-on="item.inline.events"
950
+ ></component>
918
951
  <es-input
919
952
  v-else
920
953
  v-bind="item.inline"
@@ -410,10 +410,10 @@ export default {
410
410
  return {
411
411
  placeholder: '请输入手机号',
412
412
  rules: [
413
- { required: true, message: '手机号不能为空', trigger: 'blur' },
413
+ { required: true, message: '手机号不能为空', trigger: 'change' },
414
414
  {
415
415
  ...rules.phone,
416
- trigger: 'blur'
416
+ trigger: 'change'
417
417
  }
418
418
  ]
419
419
  };
@@ -428,7 +428,7 @@ export default {
428
428
  {
429
429
  required: true,
430
430
  message: '请输入邮箱地址',
431
- trigger: 'blur'
431
+ trigger: 'change'
432
432
  },
433
433
  {
434
434
  type: 'email',
@@ -444,7 +444,9 @@ export default {
444
444
  default: () => {
445
445
  return {
446
446
  placeholder: '请输入密码',
447
- rules: [{ required: true, message: '密码不能为空', trigger: 'blur' }]
447
+ rules: [
448
+ { required: true, message: '密码不能为空', trigger: 'change' }
449
+ ]
448
450
  };
449
451
  }
450
452
  },