欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue之ElementUI Form表單校驗(yàn)

 更新時(shí)間:2021年08月24日 10:57:26   作者:前端菜鳥-AllenYe  
這篇文章主要為大家詳細(xì)介紹了Vue之ElementUI Form表單校驗(yàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

表單校驗(yàn)是前端開發(fā)過(guò)程中最常用到的功能之一,根據(jù)個(gè)人的工作經(jīng)驗(yàn)總結(jié)在此對(duì)表單校驗(yàn)功能的基礎(chǔ)用法進(jìn)行整理說(shuō)明。

以下是form的demo

el-form :model="dynamicValidateForm" ref="dynamicValidateForm" label-width="100px" class="demo-dynamic">
  <el-form-item
    prop="email"
    label="郵箱"
    :rules="[
      { required: true, message: '請(qǐng)輸入郵箱地址', trigger: 'blur' },
      { type: 'email', message: '請(qǐng)輸入正確的郵箱地址', trigger: ['blur', 'change'] }
    ]"
  >
    <el-input v-model="dynamicValidateForm.email"></el-input>
  </el-form-item>
  <el-form-item
    v-for="(domain, index) in dynamicValidateForm.domains"
    :label="'域名' + index"
    :key="domain.key"
    :prop="'domains.' + index + '.value'"
    :rules="{
      required: true, message: '域名不能為空', trigger: 'blur'
    }"
  >
    <el-input v-model="domain.value"></el-input><el-button @click.prevent="removeDomain(domain)">刪除</el-button>
  </el-form-item>
  <el-form-item>
    <el-button type="primary" @click="submitForm('dynamicValidateForm')">提交</el-button>
    <el-button @click="addDomain">新增域名</el-button>
    <el-button @click="resetForm('dynamicValidateForm')">重置</el-button>
  </el-form-item>
</el-form>
<script>
  export default {
    data() {
      return {
        dynamicValidateForm: {
          domains: [{
            value: ''
          }],
          email: ''
        }
      };
    },
    methods: {
      submitForm(formName) {
        this.$refs[formName].validate((valid) => {
          if (valid) {
            alert('submit!');
          } else {
            console.log('error submit!!');
            return false;
          }
        });
      },
      resetForm(formName) {
        this.$refs[formName].resetFields();
      },
      removeDomain(item) {
        var index = this.dynamicValidateForm.domains.indexOf(item)
        if (index !== -1) {
          this.dynamicValidateForm.domains.splice(index, 1)
        }
      },
      addDomain() {
        this.dynamicValidateForm.domains.push({
          value: '',
          key: Date.now()
        });
      }
    }
  }
</script>

首先對(duì)el-form標(biāo)簽中的幾個(gè)關(guān)鍵屬性進(jìn)行說(shuō)明

  • ref: 當(dāng)前表單的唯一標(biāo)識(shí)
  • model: 表單綁定的對(duì)象
  • rules: 字段校驗(yàn)規(guī)則

rules字段用來(lái)定義各個(gè)字段具體的校驗(yàn)規(guī)則,用法請(qǐng)查閱開篇的demo示例,其中required標(biāo)識(shí)字段是否必填,message為校驗(yàn)提示語(yǔ),trigger為單個(gè)校驗(yàn)觸發(fā)方式;也可以通過(guò)validator字段自定義校驗(yàn)規(guī)則,方法validateProductName中對(duì)商品名稱做了判空及長(zhǎng)度校驗(yàn),需要注意的是所有的條件分支都要做callback處理,否則校驗(yàn)可能會(huì)導(dǎo)致異常。

1、重置表單

調(diào)用表單重置方法this.$refs.dynamicValidateForm.resetFields()實(shí)現(xiàn)。

當(dāng)然像datetimerange類型的日期控件是無(wú)法通過(guò)該方法進(jìn)行重置,必須手動(dòng)重置綁定的字段。

2、 清除校驗(yàn)提示語(yǔ)

調(diào)用方法this.$refs.dynamicValidateForm.clearValidate()實(shí)現(xiàn)。

如果僅需要清除單個(gè)控件的提示語(yǔ),只要把該控件對(duì)應(yīng)的prop屬性值作為參數(shù)傳入即可。

還有另外一種方式就是在該控件對(duì)應(yīng)的el-form-item標(biāo)簽中增加ref屬性值,然后調(diào)用clearValidate方法。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue實(shí)現(xiàn)顯示消息提示框功能

    vue實(shí)現(xiàn)顯示消息提示框功能

    這篇文章主要介紹了vue實(shí)現(xiàn)顯示消息提示框功能,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • vue中重定向redirect:‘/index‘,不顯示問(wèn)題、跳轉(zhuǎn)出錯(cuò)的完美解決

    vue中重定向redirect:‘/index‘,不顯示問(wèn)題、跳轉(zhuǎn)出錯(cuò)的完美解決

    這篇文章主要介紹了vue中重定向redirect:‘/index‘,不顯示問(wèn)題、跳轉(zhuǎn)出錯(cuò)的完美解決方案,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2020-09-09
  • Vue 應(yīng)用中結(jié)合vux使用微信 jssdk的方法

    Vue 應(yīng)用中結(jié)合vux使用微信 jssdk的方法

    今天小編就為大家分享一篇Vue 應(yīng)用中結(jié)合vux使用微信 jssdk的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • 解決vue3項(xiàng)目中el-menu不兼容SSR問(wèn)題

    解決vue3項(xiàng)目中el-menu不兼容SSR問(wèn)題

    這篇文章主要介紹了解決vue3項(xiàng)目中el-menu不兼容SSR問(wèn)題,需要的朋友可以參考下
    2023-12-12
  • Vue如何實(shí)現(xiàn)分批加載數(shù)據(jù)

    Vue如何實(shí)現(xiàn)分批加載數(shù)據(jù)

    這篇文章主要介紹了Vue如何實(shí)現(xiàn)分批加載數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 解決vue項(xiàng)目運(yùn)行npm run serve報(bào)錯(cuò)的問(wèn)題

    解決vue項(xiàng)目運(yùn)行npm run serve報(bào)錯(cuò)的問(wèn)題

    這篇文章主要介紹了解決vue項(xiàng)目運(yùn)行npm run serve報(bào)錯(cuò)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-10-10
  • vue組件style中scoped的作用及說(shuō)明

    vue組件style中scoped的作用及說(shuō)明

    這篇文章主要介紹了vue組件style中scoped的作用及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-09-09
  • 詳解vue更改頭像功能實(shí)現(xiàn)

    詳解vue更改頭像功能實(shí)現(xiàn)

    這篇文章主要介紹了vue更改頭像功能實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • vue3中的抽離封裝方法實(shí)現(xiàn)

    vue3中的抽離封裝方法實(shí)現(xiàn)

    vue3中的任何一個(gè)組合式api都可以單獨(dú)抽離出去在另一個(gè)文件,最后只需要回歸到setup()中即可,這篇文章主要介紹了vue3的抽離封裝方法,需要的朋友可以參考下
    2022-08-08
  • 手把手教你創(chuàng)建vue3項(xiàng)目的最佳方式

    手把手教你創(chuàng)建vue3項(xiàng)目的最佳方式

    如今的Vue3已經(jīng)勢(shì)不可擋,當(dāng)然搭建一個(gè)全新的Vue3項(xiàng)目也有了全新的方式,下面這篇文章主要給大家介紹了關(guān)于如何手把手教你創(chuàng)建vue3項(xiàng)目的最佳方式,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11

最新評(píng)論