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

詳解element-ui設置下拉選擇切換必填和非必填

 更新時間:2019年06月17日 09:50:20   作者:淺吟輕唱  
這篇文章主要介紹了詳解element-ui設置下拉選擇切換必填和非必填,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

➢ 需求

默認都是必選

下拉選擇的時候

選擇必填,活動名稱為必填,需要校驗和顯示*

選擇非必填,活動名稱不做校驗,隱藏*

➢ 初始校驗規(guī)則

經(jīng)測試,網(wǎng)上其他的方式都沒有實現(xiàn)需求,動態(tài)切換rules中的required沒有作用

因為按照以下的寫法的話,element-ui在組件初始化后校驗規(guī)則就定型了,切換也沒用

rules: {
  name: [
    { required: true, message: "請輸入名稱", trigger: "blur" }
  ],
  region: [
    { required: true, message: "請選擇類型", trigger: "blur" }
  ]
}

➢ 解決方案

第一步:

去除rules中需要動態(tài)校驗的字段規(guī)則

去除name

rules: {
  region: [
    { required: true, message: "請選擇類型", trigger: "blur" }
  ]
}

第二步:

在字段為nameform-item上,添加required屬性

下面代碼isHaveTo為新字段,根據(jù)下拉框選擇的值來決定是為true還是false

<el-form-item label="活動名稱" prop="name" :required="isHaveTo">
  <el-input v-model="ruleForm.name"></el-input>
</el-form-item>

第三步:

計算屬性,新增字段isHaveTo

下拉選擇框非必須是為1,其他都是必填,包括默認

<el-form-item label="活動名稱" prop="name" :required="isHaveTo">
  <el-input v-model="ruleForm.name"></el-input>
</el-form-item>

效果如圖:

下拉切換,*號顯隱,提交時也有不同規(guī)則

注意,新的問題來了

在選擇必填時,沒有了之前的錯誤提示文字,而是element自帶的提示

第四步:

設置錯誤提示

使用自定義函數(shù)控制流程

name字段重新加回去rules

注意是函數(shù){ validator: validateName }

rules: {
  name: [{ validator: validateName }],
  region: [
    { required: true, message: "請選擇類型", trigger: "blur" }
  ]
}

然后設置函數(shù)validateName

可以看到,必填時按照我們設置的提示語提示,非必填時,校驗通過

貼上代碼

 data() {
   // 驗證活動名稱的函數(shù)
   let validateName = (rule, value, callback) => {
     // 當活動名稱為空值且為必填時,拋出錯誤,反之通過校驗
     if (this.ruleForm.name === "" && this.isHaveTo) {
       callback(new Error("請輸入活動名稱"));
     } else {
       callback();
     }
   };
   return {
     ruleForm: {
       name: "",
       region: ""
     },
     rules: {
       name: [{ validator: validateName }],
       region: [
         { required: true, message: "請選擇類型", trigger: "blur" }
       ]
     }
   };
 },

➢ 完整demo代碼

demo使用vue-cli,引入element-ui

核心代碼參考如下:

<template>
  <div>
    <el-form
      :model="ruleForm"
      :rules="rules"
      ref="ruleForm"
      label-width="100px"
      class="demo-ruleForm"
    >
      <el-form-item label="活動名稱" prop="name" :required="isHaveTo">
        <el-input v-model="ruleForm.name"></el-input>
      </el-form-item>
      <el-form-item label="活動區(qū)域" prop="region">
        <el-select v-model="ruleForm.region" placeholder="請選擇活動區(qū)域" style="width:100%">
          <el-option label="必填" value="0"></el-option>
          <el-option label="非必填" value="1"></el-option>
        </el-select>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" @click="submitForm('ruleForm')">立即創(chuàng)建</el-button>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
export default {
  name: "HelloWorld",
  data() {
    // 驗證活動名稱的函數(shù)
    let validateName = (rule, value, callback) => {
      // 當活動名稱為空值且為必填時,拋出錯誤,反之通過校驗
      if (this.ruleForm.name === "" && this.isHaveTo) {
        callback(new Error("請輸入活動名稱"));
      } else {
        callback();
      }
    };
    return {
      ruleForm: {
        name: "",
        region: ""
      },
      rules: {
        name: [{ validator: validateName }],
        region: [
          { required: true, message: "請選擇類型", trigger: "blur" }
        ]
      }
    };
  },
  computed: {
    isHaveTo: function() {
      return this.ruleForm.region !== `1`;
    }
  },
  methods: {
    submitForm(formName) {
      this.$refs[formName].validate(valid => {
        if (valid) {
          console.log(`已提交表單`);
        } else {
          console.log("error submit!!");
          return false;
        }
      });
    }
  }
};
</script>

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • vue實現(xiàn)滑動超出指定距離回頂部功能

    vue實現(xiàn)滑動超出指定距離回頂部功能

    這篇文章主要為大家詳細介紹了vue實現(xiàn)滑動超出指定距離回頂部功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • elementUI中input回車觸發(fā)頁面刷新問題與解決方法

    elementUI中input回車觸發(fā)頁面刷新問題與解決方法

    這篇文章主要給大家介紹了關于elementUI中input回車觸發(fā)頁面刷新問題與解決方法,文中通過實例代碼介紹的非常詳細,對大家學習或者使用elementUI具有一定的參考學習價值,需要的朋友可以參考下
    2023-07-07
  • vue實現(xiàn)小球滑動交叉效果

    vue實現(xiàn)小球滑動交叉效果

    這篇文章主要為大家詳細介紹了vue實現(xiàn)小球滑動交叉,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • vue實現(xiàn)帶放大鏡的搜索框

    vue實現(xiàn)帶放大鏡的搜索框

    這篇文章主要為大家詳細介紹了vue實現(xiàn)帶放大鏡的搜索框,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Vue項目查看當前使用的elementUI版本的方法

    Vue項目查看當前使用的elementUI版本的方法

    今天小編就為大家分享一篇Vue項目查看當前使用的elementUI版本的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Vue3將虛擬節(jié)點渲染到網(wǎng)頁初次渲染詳解

    Vue3將虛擬節(jié)點渲染到網(wǎng)頁初次渲染詳解

    這篇文章主要為大家介紹了Vue3將虛擬節(jié)點渲染到網(wǎng)頁初次渲染詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • vue3和ts封裝axios以及使用mock.js詳解

    vue3和ts封裝axios以及使用mock.js詳解

    目前前端最流行的網(wǎng)絡請求庫還是axios,所以對axios的封裝很有必要,下面這篇文章主要給大家介紹了關于vue3和ts封裝axios以及使用mock.js的相關資料,文章通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • VUE使用draggable實現(xiàn)組件拖拽

    VUE使用draggable實現(xiàn)組件拖拽

    這篇文章主要為大家詳細介紹了VUE使用draggable實現(xiàn)組件拖拽,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • element-ui多選表格禁用某一行不被選擇問題

    element-ui多選表格禁用某一行不被選擇問題

    這篇文章主要介紹了element-ui多選表格禁用某一行不被選擇問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue項目遇見事件冒泡該如何處理詳解

    vue項目遇見事件冒泡該如何處理詳解

    冒泡事件處理是由內(nèi)而外發(fā)生的,例如有兩個父子div,給他們分別寫上點擊事件,點擊子div先響應的是子div,再是父div,下面這篇文章主要給大家介紹了關于vue項目遇見事件冒泡該如何處理的相關資料,需要的朋友可以參考下
    2023-04-04

最新評論