亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue獲取el-form的整體驗(yàn)證狀態(tài)

 更新時(shí)間:2022年08月10日 09:42:26   作者:悟空和大王  
本文主要介紹了vue獲取el-form的整體驗(yàn)證狀態(tài),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

el-form-item 的驗(yàn)證狀態(tài)在 validateState 屬性中,該屬性的值, 默認(rèn)為:空字符串,驗(yàn)證通過為success, 驗(yàn)證失敗為error

如果需要在一開始就要通過表單數(shù)據(jù)的驗(yàn)證狀態(tài),決定操作按鈕(如:保存)是否禁用,那么需要注意兩點(diǎn):

  • 需要通過如下方式獲取驗(yàn)證狀態(tài)
    // this.$refs.validateForm 表示一個(gè)el-form
    // this.$refs.validateForm.fields 表示所有el-form-item
    // validateStateArr結(jié)果大概會(huì)是:['','success','error']
    const validateStateArr = this.$refs.validateForm.fields.map((item) => {
        return item.validateState;
      })
  • 有兩種情況表示驗(yàn)證不通過:
    • A情況:el-form-item的validateState為error.
    • B情況:el-form-item存在驗(yàn)證規(guī)則,但validateState為空字符串.

示例代碼:

<template>
  <div>
    <el-form
      ref="validateForm"
      :model="formData"
      @validate="onValidate"
      :status-icon="true"
    >
      <el-form-item label="姓名" :rules="ruleObj.name" prop="name">
        <el-input v-model="formData.name"></el-input>
      </el-form-item>
      <el-form-item label="狀態(tài)" :rules="ruleObj.status" prop="status">
        <el-select v-model="formData.status">
          <el-option :value="1" label="啟用"></el-option>
          <el-option :value="2" label="禁用"></el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="賬號(hào)" :rules="ruleObj.account" prop="account">
        <el-input v-model="formData.account"></el-input>
      </el-form-item>
      <el-form-item
        label="開始日期"
        :rules="ruleObj.beginDate"
        prop="beginDate"
      >
        <el-date-picker
          type="date"
          v-model="formData.beginDate"
          placement="bottom-start"
          value-format="yyyy-MM-dd"
          @change="(values) => onChange(values, 'endDate')"
        ></el-date-picker>
      </el-form-item>
      <el-form-item label="結(jié)束日期" :rules="ruleObj.endDate" prop="endDate">
        <el-date-picker
          type="date"
          v-model="formData.endDate"
          placement="bottom-start"
          value-format="yyyy-MM-dd"
          @change="(values) => onChange(values, 'beginDate')"
        ></el-date-picker>
      </el-form-item>
    </el-form>
    <el-button type="primary" :disabled="!validatePass" @click="onSave">
      保存
    </el-button>
  </div>
</template>

<script>
export default {
  name: "StyleTextPage",
  data() {
    return {
      formData: {
        status: null,
        name: null,
        account: null,
        endDate: null,
        beginDate: null,
      },
      // 表單是否整體通過驗(yàn)證
      validatePass: false,
      // 賬號(hào)ajax是否正處于驗(yàn)證中
      accountAjaxValidating: false,
      ruleObj: {
        endDate: [
          {
            validator: (rule, value, callback) => {
              if (this.formData.beginDate === this.formData.endDate) {
                return callback(new Error("開始日期不能等于結(jié)束日期"));
              } else {
                // 如果即在endDate驗(yàn)證成功時(shí),立即觸發(fā)beginDate的驗(yàn)證,且在beginDate驗(yàn)證成功時(shí),立即觸發(fā)endDate的驗(yàn)證會(huì)導(dǎo)致驗(yàn)證死循環(huán),因此這種驗(yàn)證,只能在change事件中觸發(fā)
                // this.$nextTick(() => {
                //   this.$refs.validateForm.validateField("beginDate");
                // });
                return callback();
              }
            },
            trigger: "change",
          },
        ],
        beginDate: [
          {
            validator: (rule, value, callback) => {
              if (this.formData.beginDate === this.formData.endDate) {
                return callback(new Error("開始日期不能等于結(jié)束日期"));
              } else {
                // 如果即在beginDate驗(yàn)證成功時(shí),立即觸發(fā)endDate的驗(yàn)證,且在endDate驗(yàn)證成功時(shí),立即觸發(fā)beginDate的驗(yàn)證會(huì)導(dǎo)致驗(yàn)證死循環(huán),因此這種驗(yàn)證,只能在change事件中觸發(fā)
                // this.$nextTick(() => {
                //   this.$refs.validateForm.validateField("endDate");
                // });
                return callback();
              }
            },
            trigger: "change",
          },
          { required: true, message: "必填", trigger: "change" },
        ],
        name: [],
        account: [
          { required: true, message: "必填" },
          {
            validator: (rule, value, callback) => {
              console.log("自定義賬號(hào)校驗(yàn)");
              this.accountAjaxValidating = true;
              // 進(jìn)入賬號(hào)自定義驗(yàn)證方法,則將表單設(shè)置為驗(yàn)證不通過(用來保證setTimeout休眠期間,保存按鈕是不可用的),最中是否通過由setTimeout的結(jié)果決定
              this.validatePass = false;
              setTimeout(() => {
                console.log("獲取到驗(yàn)證結(jié)果");
                this.accountAjaxValidating = false;
                if (value === "111") {
                  return callback(new Error("賬號(hào)已存在"));
                } else {
                  return callback();
                }
              }, 2000);
            },
            trigger: "blur",
          },
        ],
        status: [{ required: true, message: "必填" }],
      },
    };
  },
  mounted() {
    console.log(this.$refs.validateForm.fields);
    this.updateFormValidateStatus();
  },
  methods: {
    onChange(val, relValidateField) {
      console.log(val, relValidateField);
      this.$refs.validateForm.validateField(relValidateField);
    },
    updateFormValidateStatus() {
      let validateStateArr = [];
      if (this.$refs.validateForm) {
        validateStateArr = this.$refs.validateForm.fields.map((item) => {
          if (item.validateState) {
            return item.validateState;
          } else if (item.rules && item.rules.length > 0) {
            return "error";
          } else {
            return "success";
          }
        });
      }
      this.validatePass =
        !this.accountAjaxValidating &&
        validateStateArr.find((item) => item === "error") !== "error";
    },
    onValidate(...args) {
      console.log("args", args);
      this.updateFormValidateStatus();
    },
    async onSave() {
      try {
        await this.$refs.validateForm.validate();
      } catch (e) {
        console.error(e);
      }
    },
  },
};
</script>

<style scoped></style>

到此這篇關(guān)于vue獲取el-form的整體驗(yàn)證狀態(tài)的文章就介紹到這了,更多相關(guān)vue獲取el-form的整體驗(yàn)證狀態(tài)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue2路由方式--嵌套路由實(shí)現(xiàn)方法分析

    vue2路由方式--嵌套路由實(shí)現(xiàn)方法分析

    這篇文章主要介紹了vue2嵌套路由實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了vue2嵌套路由基本實(shí)現(xiàn)方法與操作注意事項(xiàng),需要的朋友可以參考下
    2020-03-03
  • vue-cli的webpack模板項(xiàng)目配置文件分析

    vue-cli的webpack模板項(xiàng)目配置文件分析

    本篇文章主要對(duì)vue-cli的webpack模板項(xiàng)目配置文件進(jìn)行分析。具有很好的參考價(jià)值。下面跟著小編一起來看下吧
    2017-04-04
  • 利用Vue.js實(shí)現(xiàn)checkbox的全選反選效果

    利用Vue.js實(shí)現(xiàn)checkbox的全選反選效果

    最近用vue做了兩個(gè)項(xiàng)目,都需要實(shí)現(xiàn)全選反選的功能,所以想著記錄下分享給大家,方便自己或者有需要的朋友們參考講學(xué)習(xí),所以下面這篇文章主要介紹了利用Vue.js實(shí)現(xiàn)checkbox的全選反選效果,需要的朋友可以一起來學(xué)習(xí)學(xué)習(xí)。
    2017-01-01
  • vue如何將v-for中的表格導(dǎo)出來

    vue如何將v-for中的表格導(dǎo)出來

    這篇文章主要介紹了vue如何將v-for中的表格導(dǎo)出來,需要的朋友可以參考下
    2018-05-05
  • Vue 列表上下過渡效果的實(shí)例代碼

    Vue 列表上下過渡效果的實(shí)例代碼

    最近有個(gè)需求,一個(gè)列表上下移動(dòng)要有簡(jiǎn)單過渡效果。本文通過實(shí)例代碼給大家介紹Vue 列表上下過渡效果,需要的朋友可以參考下
    2019-06-06
  • vue3.0實(shí)現(xiàn)復(fù)選框組件的封裝

    vue3.0實(shí)現(xiàn)復(fù)選框組件的封裝

    這篇文章主要為大家詳細(xì)介紹了vue3.0實(shí)現(xiàn)復(fù)選框組件的封裝代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • vuex刷新之后數(shù)據(jù)丟失,數(shù)據(jù)持久化,vuex-persistedstate問題

    vuex刷新之后數(shù)據(jù)丟失,數(shù)據(jù)持久化,vuex-persistedstate問題

    這篇文章主要介紹了vuex刷新之后數(shù)據(jù)丟失,數(shù)據(jù)持久化,vuex-persistedstate問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vuex 中插件的編寫案例解析

    vuex 中插件的編寫案例解析

    Vuex 的 store 接受 plugins 選項(xiàng),這個(gè)選項(xiàng)暴露出每次 mutation 的鉤子。Vuex 插件就是一個(gè)函數(shù),這篇文章主要介紹了vuex 中插件的編寫案例,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-06-06
  • vuejs簡(jiǎn)單驗(yàn)證碼功能完整示例

    vuejs簡(jiǎn)單驗(yàn)證碼功能完整示例

    這篇文章主要介紹了vuejs簡(jiǎn)單驗(yàn)證碼功能,結(jié)合完整實(shí)例形式分析了vue.js驗(yàn)證碼的生成、顯示、校驗(yàn)等相關(guān)操作技巧,需要的朋友可以參考下
    2019-01-01
  • Vue導(dǎo)出頁面為PDF格式的實(shí)現(xiàn)思路

    Vue導(dǎo)出頁面為PDF格式的實(shí)現(xiàn)思路

    這篇文章主要介紹了Vue導(dǎo)出頁面為PDF格式的實(shí)現(xiàn)思路,其實(shí)思路也很簡(jiǎn)單,就是將頁面轉(zhuǎn)換成圖片格式.然后通過圖片的base64碼.生成PDF..感興趣的朋友跟隨腳本之家小編一起看看吧
    2018-07-07

最新評(píng)論