首頁 >web前端 >js教程 >如何實作vue動態綁定元件子父元件多表單驗證

如何實作vue動態綁定元件子父元件多表單驗證

php中世界最好的语言
php中世界最好的语言原創
2018-05-30 09:27:292102瀏覽

這次帶給大家如何實作vue動態綁定元件子父元件多表單驗證,實作vue動態綁定元件子父元件多表單驗證的注意事項有哪些,下面就是實戰案例,一起來看一下。

前端專案中經常會下拉或選項卡,如果透過if,else或switch去判斷載入的話會產生大量冗餘程式碼和變數定義,而且都寫在一起後人很難維護。

Vue核心在於元件,如果有內容透過選項卡或下拉框切換用動態載入子元件最好不過。

如圖:selects資料夾中,index只負責公共資料(當然公共資料也可以寫在其他文件,只留一個入口文件 ),而comp資料夾中的幾個元件則透過動態載入。

動態載入子元件:component

// 给下拉框绑定下拉列表的索引
<el-select v-model="value" placeholder="请选择" style="float:left" @change="selectNum(value)">
     <el-option
         v-for="item in options"
         :key="item.value"
         :label="item.label"
         :value="item.value">
     </el-option>
</el-select>

引入元件後放到一個陣列內,透過控制對應的索引達到載入元件的目的

// 加载组件:每次下拉框监听则给changValue新赋值,如果下拉options的value从0开始则绑定组件时不用-1
<component :is="componentName[changValue - 1]" ref="subjectChild" @isSubmit="getSubmit"></component>

子父元件表單一起驗證:

按鈕放在父元件內:

子元件:自訂驗證規則

data(){
  const num = (rule, value, callback) => {
    let num = /^\d+$/
    if(!value){
      return callback(new Error('数量不能为空'))
    }else if(!num.test(value)){
      return callback(new Error('数量必须为数字'))
    }else{
      callback()
    }
  }
  const price = (rule, value, callback) => {
    let num2 = /^\d+$/
    if(!value){
      return callback(new Error('单价不能为空'))
    }else if(!num2.test(value)){
      return callback(new Error('单价必须为数字'))
    }else{
      callback()
    }
  }
  return{
    // 验证
    apple:{
      num: '',
      price: '',
    },
    reg:{
      num: [
        { validator: num, trigger: 'blur' }
      ],
      price: [
        { validator: price, trigger: 'blur' }
      ]
    }
  }
// 验证
  submitForm(){
    this.$refs.apple.validate((valid) => {
      if(valid){
        this.$emit('isSubmit',["subject",true])
      }else{
        this.$emit('isSubmit',["subject",false])
        return false
      }
    })
  }

父元件:

 // 获取子组件状态
  getSubmit(type){
    this.isRule = type[1]
  },
// 公共数据验证
  submitForm2(){
    // 如果选中了子组件
    if(this.changValue){
      this.$refs.subjectChild.submitForm()
    }
    let _this = this
    let p1 = new Promise((resolve, reject) => {
      _this.$refs.ruleForm.validate((valid) => {
        if(valid){
          resolve()
        }
      })
    })
    if(_this.isRule){
      Promise.all([p1]).then(() => {
        console.log('正确')
      })
      .catch(() => {
        console.log('错误')
      })
    }else{
      console.log('错误')
    }
  },

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

如何使用js封裝ajax函數函數與用法

JS中有哪些常用數學函數?

#

以上是如何實作vue動態綁定元件子父元件多表單驗證的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn