Maison >interface Web >Voir.js >Comment Vue+ElementUI gère les formulaires surdimensionnés

Comment Vue+ElementUI gère les formulaires surdimensionnés

青灯夜游
青灯夜游avant
2021-11-22 19:49:492401parcourir

Cet article vous montrera comment traiter des formulaires très volumineux avec Vue + ElementUI. J'espère qu'il vous sera utile !

Comment Vue+ElementUI gère les formulaires surdimensionnés

En raison des récents ajustements commerciaux dans l'entreprise, la logique de la forme longue précédente a beaucoup changé, j'ai donc l'intention de la reconstruire (elle a été écrite par un responsable d'arrière-plan qui a démissionné, et il n'y a pas de commentaires. Un composant a écrit 4000 + OK, je suis vraiment impuissant). Pour votre commodité, j'ai divisé le projet en 14 composants et je l'ai simplifié. 14个组件进行了精简。

整体思路

  • 大表单根据业务模块进行拆分
  • 保存时使用el-form提供的validate方法进行校验(循环对每一个拆分的组件进行校验)
  • mixin 对每个组件的公共提取(也利于后期项目的维护)

【相关推荐:《vue.js教程》】

开始

  • 这里以拆分2个组件为例:form1, form2(方便读者观看,命名勿喷)
  • 这里两个组件为什么ref、model绑定的都是form后边会进行说明(为了方便后期维护)
// form1 组件
<template>
    <el-form
      ref="form"
      :model="form"
      label-width="10px"
    >
      <el-form-item label="姓名" prop="name">
          <el-input v-model="form.name" />
      </el-form-item>
    </el-form>
</template>
<script>
export default {
  name: &#39;Form1&#39;,
    props: {
      form: {}
  },
  data() {
    return {
      rules: {
        name: [
          { required: true, message: &#39;请输入姓名&#39;, trigger: &#39;blur&#39; }
        ]
      }
    }
  },
  methods: {
    // 这里是是为了父组件循环调用校验
    validForm() {
        let result = false
        this.$refs.form.validate(valid => valid && (result = true))
        return result
    }
    // 我这里还用了另一种方式写的,但是循环校验的时候是promise对象,有问题,望大佬们指点一二
    validForm() {
        // 明明这里输出的结构是 Boolean 值,但在父组件循环调用之后就是promise类型,需要转换一下才行
        return this.$refs.form.validate().catch(e => console.log(e))
    }
  }
}
</script>

// form2 组件
<template>
    <el-form
      ref="form"
      :model="form"
      label-width="10px"
    >
      <el-form-item label="年龄" prop="age">
          <el-input v-model="form.age" />
      </el-form-item>
    </el-form>
</template>
<script>
export default {
  name: &#39;Form2&#39;,
  props: {
      form: {}
  },
  data() {
    return {
      rules: {
        name: [
          { required: true, message: &#39;请输入年龄&#39;, trigger: &#39;blur&#39; }
        ]
      }
    }
  },
  methods: {
    // 这里是是为了父组件循环调用校验
    validForm() {
        let result = false
        this.$refs.form.validate(valid => valid && (result = true))
        return result
    }
  }
}
</script>
  • 看一下父组件怎么引用的
// 父组件
<template>
    <div class="parent">
        <form1 ref="form1" :form="formData.form1" />
        <form2 ref="form2" :form="formData.form2" />
        <el-button type="primary" @click="save">报错</el-button>
    </div>
</template>
<script>
... 省略引用
export default {
    name: &#39;parent&#39;,
    ... 省略注册
    data () {
        return {
            formData: {
                form1: {},
                form2: {}
            }
        }
    },
}
</script>
  • 由于formData里的属性名form1form2分别用在子表单组件的ref上,因此可以在遍历时依次找到他们,修改保存函数,代码如下:
methods: {
    save () {
        // 每个表单对象的 key 值,也就是每个表单的 ref 值
        const formKeys = Object.keys(this.formData)
        // 执行每个表单的校验方法
        const valids = formKeys.map(item => this.$refs[item].validForm())
        // 所有表单通过检验之后的逻辑
        if (valids.every(item => item)) {
          console.log(11)
        }
    }
}

解答为什么两个组件ref、model绑定的都是form

  • 通过对比我们可以发现form1 form2有共同的 props methods
  • 我们通过 mixin 提取一下
export default {
  props: {
    form: {
      required: true,
      type: Object,
      default: () => {}
    },
  },
  methods: {
    validForm () {
      let result = false
      this.$refs.form.validate(valid => valid && (result = true))
      return result
    }
  }
}
  • form1 form2 中引用该minix

    Idée globale

Les grands formulaires sont divisés en fonction des modules métiers

    Utilisez le validatefourni par el-form lors de l'enregistrement >Méthode de vérification (Vérification en boucle de chaque composant fractionné)
  • mixin extraction publique de chaque composant (également propice à la maintenance des projets ultérieurs)
  • [Recommandations associées : 《tutoriel vue.js
  • 》】

Démarrez

ici Prenez splitting 2 composants à titre d'exemple : form1, form2 (pour la commodité des lecteurs, veuillez ne pas utiliser de noms)

🎜Pourquoi les deux composants sont-ils iciref et model sont liés au form qui sera expliqué plus tard (pour la commodité d'une maintenance ultérieure)🎜🎜rrreee🎜🎜Regardez comment le composant parent est référencé🎜🎜rrreee🎜🎜 Parce que les noms d'attribut form1 et form2 dans formData sont utilisés respectivement sur le ref du composant de sous-formulaire, ils peut être parcouru Trouvez-les tour à tour et modifiez la fonction de sauvegarde. Le code est le suivant : 🎜🎜rrreee

Répondez pourquoi les deux composants ref et model sont lié au formulaire 🎜🎜🎜Par comparaison, nous pouvons constater que form1 form2 a les mêmes méthodes props🎜🎜Nous l'extrayons via mixin🎜🎜 rrreee🎜🎜in Référencez le <code>minix dans form1 form2 et supprimez les attributs et méthodes correspondants dans le composant correspondant🎜🎜🎜Fin🎜🎜🎜Il est très difficile à résoudre extrêmement les grandes formes, voici juste pour le fractionnement des composants🎜🎜la liaison entre les composants est également une grosse difficulté, je le publierai après l'avoir terminé la prochaine fois🎜🎜Vous êtes invités à discuter de la façon dont vous l'avez résolu dans la zone de commentaire, et vous l'êtes. bienvenue également pour signaler les lacunes à l'auteur🎜🎜🎜Plus de programmation Pour des connaissances connexes, veuillez visiter : 🎜Introduction à la programmation🎜 ! ! 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer