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

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

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

➢ 需求

默認(rèn)都是必選

下拉選擇的時(shí)候

選擇必填,活動(dòng)名稱為必填,需要校驗(yàn)和顯示*

選擇非必填,活動(dòng)名稱不做校驗(yàn),隱藏*

➢ 初始校驗(yàn)規(guī)則

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

因?yàn)榘凑找韵碌膶懛ǖ脑挘?code>element-ui在組件初始化后校驗(yàn)規(guī)則就定型了,切換也沒用

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

➢ 解決方案

第一步:

去除rules中需要?jiǎng)討B(tài)校驗(yàn)的字段規(guī)則

去除name

rules: {
  region: [
    { required: true, message: "請(qǐng)選擇類型", trigger: "blur" }
  ]
}

第二步:

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

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

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

第三步:

計(jì)算屬性,新增字段isHaveTo

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

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

效果如圖:

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

注意,新的問題來(lái)了

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

第四步:

設(shè)置錯(cuò)誤提示

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

name字段重新加回去rules

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

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

然后設(shè)置函數(shù)validateName

可以看到,必填時(shí)按照我們?cè)O(shè)置的提示語(yǔ)提示,非必填時(shí),校驗(yàn)通過

貼上代碼

 data() {
   // 驗(yàn)證活動(dòng)名稱的函數(shù)
   let validateName = (rule, value, callback) => {
     // 當(dāng)活動(dòng)名稱為空值且為必填時(shí),拋出錯(cuò)誤,反之通過校驗(yàn)
     if (this.ruleForm.name === "" && this.isHaveTo) {
       callback(new Error("請(qǐng)輸入活動(dòng)名稱"));
     } else {
       callback();
     }
   };
   return {
     ruleForm: {
       name: "",
       region: ""
     },
     rules: {
       name: [{ validator: validateName }],
       region: [
         { required: true, message: "請(qǐng)選擇類型", 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="活動(dòng)名稱" prop="name" :required="isHaveTo">
        <el-input v-model="ruleForm.name"></el-input>
      </el-form-item>
      <el-form-item label="活動(dòng)區(qū)域" prop="region">
        <el-select v-model="ruleForm.region" placeholder="請(qǐng)選擇活動(dòng)區(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() {
    // 驗(yàn)證活動(dòng)名稱的函數(shù)
    let validateName = (rule, value, callback) => {
      // 當(dāng)活動(dòng)名稱為空值且為必填時(shí),拋出錯(cuò)誤,反之通過校驗(yàn)
      if (this.ruleForm.name === "" && this.isHaveTo) {
        callback(new Error("請(qǐng)輸入活動(dòng)名稱"));
      } else {
        callback();
      }
    };
    return {
      ruleForm: {
        name: "",
        region: ""
      },
      rules: {
        name: [{ validator: validateName }],
        region: [
          { required: true, message: "請(qǐng)選擇類型", 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>

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

相關(guān)文章

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

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

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

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

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

    vue實(shí)現(xiàn)小球滑動(dòng)交叉效果

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

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

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

    Vue項(xiàng)目查看當(dāng)前使用的elementUI版本的方法

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

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

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

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

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

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

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

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

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

    vue項(xiàng)目遇見事件冒泡該如何處理詳解

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

最新評(píng)論