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

Vue-Ant Design Vue-普通及自定義校驗實例

 更新時間:2020年10月24日 10:07:48   作者:谷文杰  
這篇文章主要介紹了Vue-Ant Design Vue-普通及自定義校驗實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

這段時間在使用Ant Design Vue進行項目的前端部分開發(fā),進行一個記錄,分享…

Ant Design Vue

Ant Design Vue是 Ant Design 3.X 的 Vue 實現(xiàn),開發(fā)和服務于企業(yè)級后臺產(chǎn)品。在GitHub上可以找到幾個Ant Design的Vue組件。不過相比較而言,Ant Design Vue更勝一籌。Ant Design Vue共享Ant Design of React設計工具體系,實現(xiàn)了所有Ant Design of React的組件,支持現(xiàn)代瀏覽器和 IE9 及以上(需要 polyfills)??梢宰屖煜nt Design的在使用Vue時,很容易的上手。

nodejs,npm包括Ant Design Vue安裝什么的就不說了,可以百度,之后有時間我會寫一篇關于這一套東西的安裝教程,關于Ant Design Vue,可以直接查看官方文檔:https://vue.ant.design

下面說一下關于Ant Design Vue中的表單校驗及自定義校驗。

自定義校驗

先給一張Ant Design Vue得form表單中不同類型的校驗場景圖,看看是否有你需要的:

官方提供了 validateStatus, help ,hasFeedback 等屬性,你可以不需要使用 Form.create 和 getFieldDecorator,自己定義校驗的時機和內容。

validateStatus: 校驗狀態(tài),可選 ‘success', ‘warning', ‘error', ‘validating'。

hasFeedback:用于給輸入框添加反饋圖標。

help:設置校驗文案。

說明一點: 當你使用Ant Design Vue的使用,經(jīng)過 Form.create 包裝的組件將會自帶 this.form 屬性

this.form 提供的 關于校驗的API如下 :

方法 說明 類型
validateFields 校驗并獲取一組輸入域的值與 Error,若 fieldNames 參數(shù)為空,則校驗全部組件 Function([fieldNames: string[]], [options: object], callback: Function(errors, values))

然后看下Form.Item的參數(shù)設置(主要看關于校驗的):

參數(shù) 說明 類型 默認值
extra 額外的提示信息,和 help 類似,當需要錯誤信息和提示文案同時出現(xiàn)時,可以使用這個。 string/slot
hasFeedback 配合 validateStatus 屬性使用,展示校驗狀態(tài)圖標,建議只配合 Input 組件使用。 boolean false
help 提示信息,如不設置,則會根據(jù)校驗規(guī)則自動生成 string/slot
validateStatus 校驗狀態(tài),如不設置,則會根據(jù)校驗規(guī)則自動生成,可選:‘success' ‘warning' ‘error' ‘validating' string

最后是校驗規(guī)則設置:

相關的api及參數(shù)設置介紹完樂,下面上實例

實例

寫一個簡單的例子

form表單代碼:

<a-form style="max-width: 500px; margin: 40px auto 0;" @submit="handleSubmit" :form="form">
<a-form-item
label="密碼"
:labelCol="{span: 5}"
:wrapperCol="{span: 19}"
class="stepFormText"
hasFeedback
>
<a-input
v-decorator="[
'password',
{rules: [{ required: true, message: '請輸入密碼' },{validator: handlePass}]}
]"
name="password"
/>
</a-form-item>
<a-form-item
label="確認密碼"
:labelCol="{span: 5}"
:wrapperCol="{span: 19}"
class="stepFormText"
hasFeedback
>
<a-input
v-decorator="[
'confirm_password',
{rules: [{ required: true, message: '請輸入確認密碼' },{validator: handleConfirmPass}]}
]"
name="confirm_password"
/>
</a-form-item>
<a-form-item :wrapperCol="{span: 19, offset: 5}">
<a-button :loading="loading" type="primary" htmlType="submit">提交</a-button>
</a-form-item>
</a-form>

進行一下說明,以確認密碼的校驗為例:

<a-input
     v-decorator="[
     'confirm_password',
     {rules: [{ required: true, message: '請輸入確認密碼' },{validator: handleConfirmPass}]}
    ]"
     name="confirm_password"
   />

rules中為一個數(shù)組,每一項就是一個校驗規(guī)則,第一項規(guī)則容易理解,但是{validator: handleConfirmPass}是什么的,我們通過上面的校驗規(guī)則設置(紅框處)可以發(fā)現(xiàn),這是當你設置自定義校驗的時候需要這么寫。注意:callback 必須被調用。

handleConfirmPass 其實就是自定義校驗的校驗方法。

上js代碼:

<script>
export default {
 data () {
  return {
   labelCol: {
    xs: { span: 24 },
    sm: { span: 7 }
   },
   wrapperCol: {
    xs: { span: 24 },
    sm: { span: 13 }
   },
   password: '',
   // form
   form: this.$form.createForm(this)
  }
 },
 methods: {
  handlePass(rule,value,callback){
   this.password = value
   callback()
  },
  handleConfirmPass(rule,value, callback){
   if (this.password && this.password !== value) {
    callback('兩次密碼輸入不一致!')
   }
   // Note: 必須總是返回一個 callback,否則 validateFieldsAndScroll 無法響應
   callback()
  },
  handleSubmit (e) {
   e.preventDefault()
   this.form.validateFields((err, values) => {
    if (!err) {
     console.log(values)
    }
   })

  }
 }
}
</script>

效果圖如下:

1.空值提交

2.自定義校驗規(guī)則生效

好了,這就是關于Ant Design Vue的普通及自定義校驗的簡單使用。

補充知識:關于 Ant Design of Vue 表單動態(tài)賦值 觸發(fā)驗證 問題

關于 Ant Design of Vue 表單動態(tài)賦值 觸發(fā)驗證

Ant Design of Vue 中 給表單動態(tài)賦值 使用 setFieldsValue 方法 這一點 之前已經(jīng)介紹過了 ,不了解的可以查找我之前的博客 上面有詳細的介紹使用方法

但使用 該方法可能會出現(xiàn) 一個問題 例如本人使用的下拉框觸發(fā) change 事件的時候 給表單 動態(tài)賦值

這個時候遇到一個問題 就是 觸發(fā)的同時也觸發(fā)了表單驗證 解決的方法是 在setFieldsValue 方法的外面

加上 this.$nextTick(() => {}) 方法 如圖所示

輕松解決 問題 。

以上這篇Vue-Ant Design Vue-普通及自定義校驗實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Vue使用fabric.js實現(xiàn)局部截圖與大圖預覽功能

    Vue使用fabric.js實現(xiàn)局部截圖與大圖預覽功能

    這篇文章主要為大家詳細介紹了Vue如何使用fabric.js實現(xiàn)局部截圖與el-image-viewer大圖預覽功能,文中的示例代碼講解詳細,感興趣的可以了解下
    2024-02-02
  • 淺談Vue SSR中的Bundle的具有使用

    淺談Vue SSR中的Bundle的具有使用

    這篇文章主要介紹了淺談Vue SSR中的Bundle的具有使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • vue3+elementplus前端生成圖片驗證碼完整代碼舉例

    vue3+elementplus前端生成圖片驗證碼完整代碼舉例

    在開發(fā)過程中有時候需要使用圖片驗證碼進行增加安全強度,在點擊圖片時更新新的圖片驗證碼,記錄此功能,以便后期使用,這篇文章主要給大家介紹了關于vue3+elementplus前端生成圖片驗證碼的相關資料,需要的朋友可以參考下
    2024-03-03
  • vue實現(xiàn)淘寶購物車功能

    vue實現(xiàn)淘寶購物車功能

    這篇文章主要為大家詳細介紹了vue實現(xiàn)淘寶購物車功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • 基于vue 添加axios組件,解決post傳參數(shù)為null的問題

    基于vue 添加axios組件,解決post傳參數(shù)為null的問題

    下面小編就為大家分享一篇基于vue 添加axios組件,解決post傳參數(shù)為null的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Template?ref在Vue3中的實現(xiàn)原理詳解

    Template?ref在Vue3中的實現(xiàn)原理詳解

    這篇文章主要為大家介紹了Template?ref在Vue3中的實現(xiàn)原理示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • vue 實現(xiàn)在函數(shù)中觸發(fā)路由跳轉的示例

    vue 實現(xiàn)在函數(shù)中觸發(fā)路由跳轉的示例

    今天小編就為大家分享一篇vue 實現(xiàn)在函數(shù)中觸發(fā)路由跳轉的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • antd?select?多選限制個數(shù)的實現(xiàn)代碼

    antd?select?多選限制個數(shù)的實現(xiàn)代碼

    這篇文章主要介紹了antd?select?多選限制個數(shù),實現(xiàn)思路和核心代碼都很簡單,其中核心代碼在于disabled,代碼簡單易懂需要的朋友可以參考下
    2022-11-11
  • vue項目webpack中Npm傳遞參數(shù)配置不同域名接口

    vue項目webpack中Npm傳遞參數(shù)配置不同域名接口

    這篇文章主要介紹了vue項目webpack中Npm傳遞參數(shù)配置不同域名接口,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • vue2.x 對象劫持的原理實現(xiàn)

    vue2.x 對象劫持的原理實現(xiàn)

    這篇文章主要介紹了vue2.x 對象劫持的原理實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04

最新評論