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

實現(xiàn)elementUI表單的全局驗證的方法步驟

 更新時間:2019年04月29日 09:39:58   投稿:zx  
這篇文章主要介紹了實現(xiàn)elementUI表單的全局驗證的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

使用ElementUi搭建框架的時候,大家應該都有考慮過怎么做全局驗證,畢竟復制粘貼什么的是最煩了,這里分享下個人的解決方法。

驗證規(guī)則

分析規(guī)則

一般驗證規(guī)則,主要是是否必填,不為空,以及參數(shù)類型的驗證。 基于這個條件,我們開始找找思路, 單個字段的驗證是這樣的:

name: {
 required: 是否必填,
 validator: 自定義規(guī)則,
 message: 失敗提示消息(非自定義時觸發(fā)),
 trigger: 觸發(fā)方式
}

循環(huán)實現(xiàn)

固定的規(guī)則。當一個東西固定之后,那必然是可以重復使用的,并且可以快速生成,我們可以用循環(huán)來實現(xiàn)它。 但是用循環(huán)來實現(xiàn),我們則需要一個數(shù)據規(guī)則。

定義數(shù)據規(guī)則

分析下需要的字段,大概就是以下幾種,其他的可以根據自身的需求去增加:

  • 驗證的字段名 label
  • 驗證的值 value
  • 驗證的類型 type
  • 是否必填 required
  • 自定義規(guī)則 validator

那最終我們得到的是這樣一個字段配置列表:

fieldList: [
   {label: '賬號', value: 'account', type: 'input', required: true, validator: checkAccount},
   {label: '密碼', value: 'password', type: 'password', required: true, validator: checkPwd},
   {label: '昵稱', value: 'name', type: 'input', required: true},
   {label: '性別', value: 'sex', type: 'select', list: 'sexList', required: true},
   {label: '頭像', value: 'avatar', type: 'slot', className: 'el-form-block'},
   {label: '手機號碼', value: 'phone', type: 'input', validator: checkPhone},
   {label: '微信', value: 'wechat', type: 'input', validator: checkWechat},
   {label: 'QQ', value: 'qq', type: 'input', validator: checkQQ},
   {label: '郵箱', value: 'email', type: 'input', validator: checkEmail},
   {label: '描述', value: 'desc', type: 'textarea', className: 'el-form-block'},
   {label: '狀態(tài)', value: 'status', type: 'select', list: 'statusList', required: true}
  ]

form完整的字段配置建議參考:

  formInfo: {
  ref: null,
  data: {
   id: '', // *唯一ID
   account: '', // *用戶賬號
   password: '', // *用戶密碼
   name: '', // *用戶昵稱
   type: 2, // *用戶類型: 0: 手機注冊 1: 論壇注冊 2: 管理平臺添加
   sex: 0, // *性別: 0:男 1:女
   avatar: '', // 頭像
   phone: '', // 手機號碼
   wechat: '', // 微信
   qq: '', // qq
   email: '', // 郵箱
   desc: '', // 描述
   status: 1 // *狀態(tài): 0:停用,1:啟用(默認為1)',
   // create_user: '', // 創(chuàng)建人
   // create_time: '', // 創(chuàng)建時間
   // update_user: '', // 修改人
   // update_time: '' // 修改時間
  },
  fieldList: [
   {label: '賬號', value: 'account', type: 'input', required: true, validator: checkAccount},
   {label: '密碼', value: 'password', type: 'password', required: true, validator: checkPwd},
   {label: '昵稱', value: 'name', type: 'input', required: true},
   {label: '性別', value: 'sex', type: 'select', list: 'sexList', required: true},
   {label: '頭像', value: 'avatar', type: 'slot', className: 'el-form-block'},
   {label: '手機號碼', value: 'phone', type: 'input', validator: checkPhone},
   {label: '微信', value: 'wechat', type: 'input', validator: checkWechat},
   {label: 'QQ', value: 'qq', type: 'input', validator: checkQQ},
   {label: '郵箱', value: 'email', type: 'input', validator: checkEmail},
   {label: '描述', value: 'desc', type: 'textarea', className: 'el-form-block'},
   {label: '狀態(tài)', value: 'status', type: 'select', list: 'statusList', required: true}
  ],
  rules: {},
  labelWidth: '120px'
  }

實現(xiàn)驗證方法

一: 循環(huán)字段列表,根據type判斷是提示選擇不能為空,還是輸入不能為空
二:如果字段必填,則根據是否有自定義驗證去生成驗證規(guī)則
三: 字段非必填,有自定義規(guī)則生成驗證

 // 初始化驗證數(shù)據
 _initValidate (formInfo) {
  const obj = {},
  fieldList = formInfo.fieldList
  // 循環(huán)字段列表
  for (let item of fieldList) {
  let type = item.type === 'select' ? '選擇' : '輸入'
  if (item.required) {
   if (item.validator) {
   obj[item.value] = {
    required: item.required,
    validator: item.validator,
    trigger: 'blur'
   }
   } else {
   obj[item.value] = {
    required: item.required,
    message: '請' + type + item.label,
    trigger: 'blur'
   }
   }
  } else if (item.validator) {
   obj[item.value] = {
   validator: item.validator,
   trigger: 'blur'
   }
  }
  }
  formInfo.rules = obj
 }

使用

結合上面的字段設計,我在頁面上的使用是這樣的,大家可以根據自己的字段設計去修改,大致實現(xiàn)過程是這樣的

// mixin中的方法, 初始化字段驗證規(guī)則
this._initValidate(this.formInfo)

怎么配置到全局

  1. 通過mixin配置,然后在頁面中使用(個人使用的是mixin)
  2. 配置為全局方法在頁面中調用
  3. 掛在到vue實例上,通過this即可訪問

mixins例子

export default {
 data () {
 /**
  * 頁面上的可復用的驗證規(guī)則
  */
 // 驗證號碼格式
 const CHECK_PHONE = (rule, value, callback) => {
  let check = this.$validate({label: '號碼', value, rules: ['phone']})
  if (!check.result) {
  callback(new Error(check.message))
  } else {
  callback()
  }
 }
 // 驗證號碼格式以及不能為空
 const CHECK_PHONE_NOTNULL = (rule, value, callback) => {
  let check = this.$validate({label: '號碼', value, rules: ['notnull', 'phone']})
  if (!check.result) {
  callback(new Error(check.message))
  } else {
  callback()
  }
 }
 // 檢測郵箱格式
 const CHECK_EMAIL = (rule, value, callback) => {
  let check = this.$validate({label: '郵箱', value, rules: ['email']})
  if (!check.result) {
  callback(new Error(check.message))
  } else {
  callback()
  }
 }
 // 檢測郵箱格式以及不能為空
 const CHECK_EMAIL_NOTNULL = (rule, value, callback) => {
  let check = this.$validate({label: '郵箱', value, rules: ['notnull', 'email']})
  if (!check.result) {
  callback(new Error(check.message))
  } else {
  callback()
  }
 }
 return {
  CHECK_PHONE,
  CHECK_PHONE_NOTNULL,
  CHECK_EMAIL,
  CHECK_EMAIL_NOTNULL
 }
 },
 methods: {
 // 初始化驗證數(shù)據
 _initValidate (formInfo) {
  const obj = {},
  fieldList = formInfo.fieldList
  // 循環(huán)字段列表
  for (let item of fieldList) {
  let type = item.type === 'select' ? '選擇' : '輸入'
  if (item.required) {
   if (item.validator) {
   obj[item.value] = {
    required: item.required,
    validator: item.validator,
    trigger: 'blur'
   }
   } else {
   obj[item.value] = {
    required: item.required,
    message: '請' + type + item.label,
    trigger: 'blur'
   }
   }
  } else if (item.validator) {
   obj[item.value] = {
   validator: item.validator,
   trigger: 'blur'
   }
  }
  }
  formInfo.rules = obj
 }
 }
}

最后

在項目的系統(tǒng)管理模塊中可以看到示例代碼:

項目地址

項目代碼地址

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

相關文章

  • Vue.js最佳實踐(五招助你成為vuejs大師)

    Vue.js最佳實踐(五招助你成為vuejs大師)

    這篇文章主要介紹了Vue.js最佳實踐,本文主要面向對象是有一定vue.js 編輯經驗的開發(fā)者,需要的朋友可以參考下
    2018-05-05
  • Vue3進階主題Composition API使用詳解

    Vue3進階主題Composition API使用詳解

    這篇文章主要為大家介紹了Vue3進階主題Composition API使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • 解決echarts vue數(shù)據更新,視圖不更新問題(echarts嵌在vue彈框中)

    解決echarts vue數(shù)據更新,視圖不更新問題(echarts嵌在vue彈框中)

    這篇文章主要介紹了解決echarts vue數(shù)據更新,視圖不更新問題(echarts嵌在vue彈框中),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • vue項目環(huán)境搭建

    vue項目環(huán)境搭建

    這篇文章介紹了vue項目環(huán)境搭建的方法,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-04-04
  • vue項目如何去掉URL中#符號的方法

    vue項目如何去掉URL中#符號的方法

    在開發(fā)過程中發(fā)現(xiàn)路徑中帶有/#/的標示,而且還去不掉,很丑陋,下面這篇文章主要給大家介紹了vue項目如何去掉URL中#符號的相關資料,文中通過實例代碼的非常詳細,需要的朋友可以參考下
    2022-07-07
  • vue 組件使用中的一些細節(jié)點

    vue 組件使用中的一些細節(jié)點

    這篇文章主要介紹了vue 組件使用中的一些細節(jié)點,大概有兩大細節(jié)點,本文通過基礎實例給大家介紹的非常詳細,需要的朋友參考下吧
    2018-04-04
  • 基于vue-cli3+typescript的tsx開發(fā)模板搭建過程分享

    基于vue-cli3+typescript的tsx開發(fā)模板搭建過程分享

    這篇文章主要介紹了搭建基于vue-cli3+typescript的tsx開發(fā)模板,本文通過實例代碼截圖的形式給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • vue圖片轉base64格式的方法示例

    vue圖片轉base64格式的方法示例

    對于前后端分離的項目,為了統(tǒng)一響應參數(shù),需要將圖片轉換成base64的格式,下面這篇文章主要給大家介紹了關于vue圖片轉base64格式的相關資料,需要的朋友可以參考下
    2022-12-12
  • 基于Vue3+Three.js實現(xiàn)一個3D模型可視化編輯系統(tǒng)

    基于Vue3+Three.js實現(xiàn)一個3D模型可視化編輯系統(tǒng)

    這篇文章主要介紹了基于Vue3+Three.js實現(xiàn)一個3D模型可視化編輯系統(tǒng),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • vue踩坑記錄之echarts動態(tài)數(shù)據刷新問題

    vue踩坑記錄之echarts動態(tài)數(shù)據刷新問題

    這篇文章主要介紹了vue踩坑記錄之echarts動態(tài)數(shù)據刷新問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07

最新評論