| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- <template>
- <view class="u-form"><slot /></view>
- </template>
- <script>
- export default {
- name: 'u-form',
- props: {
- // 当前form的需要验证字段的集合
- model: {
- type: Object,
- default() {
- return {};
- }
- },
- // 验证规则
- // rules: {
- // type: [Object, Function, Array],
- // default() {
- // return {};
- // }
- // },
- // 有错误时的提示方式,message-提示信息,border-如果input设置了边框,变成呈红色,
- // border-bottom-下边框呈现红色,none-无提示
- errorType: {
- type: Array,
- default() {
- return ['message']
- }
- }
- },
- provide() {
- return {
- uForm: this
- };
- },
- data() {
- return {
- rules: {}
- };
- },
- created() {
- // 存储当前form下的所有u-form-item的实例
- // 不能定义在data中,否则微信小程序会造成循环引用而报错
- this.fields = [];
- // 存当前实例
- let that = this;
- // 监听on-form-item-add事件,将子组件添加到fields中
- this.$on('on-form-item-add', item => {
- if (item) {
- that.fields.push(item);
- }
- });
- // 删除当前有的实例
- this.$on('on-form-item-remove', item => {
- // 如果当前没有prop的话表示当前不要进行删除(因为没有注入)
- if (item.prop) {
- that.fields.splice(that.fields.indexOf(item), 1);
- }
- });
- },
- methods: {
- setRules(rules) {
- this.rules = rules;
- },
- // 清空所有u-form-item组件的内容,本质上是调用了u-form-item组件中的resetField()方法
- resetFields() {
- this.fields.map(field => {
- field.resetField();
- });
- },
- // 校验全部数据
- validate(callback) {
- return new Promise(resolve => {
- // 对所有的u-form-item进行校验
- let valid = true; // 默认通过
- let count = 0; // 用于标记是否检查完毕
- this.fields.map(field => {
- // 调用每一个u-form-item实例的validation的校验方法
- field.validation('', error => {
- // 如果任意一个u-form-item校验不通过,就意味着整个表单不通过
- if (error) valid = false;
- // 当历遍了所有的u-form-item时,调用promise的then方法
- if (++count === this.fields.length) {
- resolve(valid); // 进入promise的then方法
- // 调用回调方法
- if (typeof callback == 'function') callback(valid);
- }
- });
- });
- });
- }
- }
- };
- </script>
- <style></style>
|