成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

vue-hook-form怎么用

小編給大家分享一下vue-hook-form怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)公司作為成都網(wǎng)站建設(shè)公司,專注成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計,有關(guān)成都企業(yè)網(wǎng)站建設(shè)方案、改版、費(fèi)用等問題,行業(yè)涉及成都濕噴機(jī)等多個領(lǐng)域,已為上千家企業(yè)服務(wù),得到了客戶的尊重與認(rèn)可。

vue-hook-form

用于處理form請求,獲取formData。以便于將form請求轉(zhuǎn)成ajax/fetch請求

安裝

npm install vue-hook-form

使用

VUE版本:1.x
必須在vue-cli生成的webpack模板環(huán)境中使用

一、注冊&配置組件

// 這里使用在main.js中全局注冊來示例
import vue from 'vue'
import hookForm from 'vue-hook-form'
// 配置全局form表單序列化之前的hook
hookForm.beforeSerialize = (vm, next) => {
 // vm: 對應(yīng)的hookForm vm實例
 // next:繼續(xù)執(zhí)行
 // 你可以在此處執(zhí)行表單校驗
}
// 配置全局form提交前的hook
hookForm.onSubmit = request => {
 // request:包含了本次請求的基本信息
 // 你可以在此處執(zhí)行表單校驗或使用ajax來提交本次請求
}
vue.component('hook-form', hookForm)

Request對象:

{
 url: '請求地址',
 body: '請求參數(shù)',
 method: '請求方法',
 vm: '對應(yīng)的hookForm vm實例'
}

二、vue文件中使用

<template>
 <hook-form action="users" :on-submit="onSubmit" :before-serialize="beforeSerialize">
 <input name="name">
 <input name="age">
 <button>提交</button>
 </hook-form>
</template>
<script>
 export default {
 methods: {
  // 局部hook
  beforeSerialize (vm, next) {
  // next:繼續(xù)執(zhí)行
  // 你可以在此處執(zhí)行表單校驗
  },
  onSubmit (request) {
  // request:包含了本次請求的基本信息
  // 你可以在此處執(zhí)行表單校驗或使用ajax來提交本次請求
  }
 }
 }
</script>

配置

onSubmit

form提交前的全局hook。

beforeSerialize

form表單序列化之前的全局hook。一般用于校驗表單,但此時無須form表單序列化的時候。也便于在觸發(fā)onSubmit之前更改form表單內(nèi)容

json

Request.body是否轉(zhuǎn)成json格式,默認(rèn)為url字符串。默認(rèn):false

hookForm.onSubmit = request => {
 // request.body為url字符串格式
 // 形如:name=張三&age=18
}
// 配置Request.body為json格式
hookForm.json = true
hookForm.onSubmit = request => {
 // request.body為json格式
}

Props

action:請求地址
method:請求方法。默認(rèn):post
onSubmit:form提交前的局部hook
beforeSerialize: form表單序列化之前的局部hook
json:Request.body是否轉(zhuǎn)成json格式(優(yōu)先使用局部json配置)。默認(rèn):false
disabled:禁用

關(guān)于disabled

你可以通過使用該選項來防止form的多次提交

hookForm.onSubmit = request => {
 // 禁止form提交
 request.vm.disabled = true
 // 在ajax請求或其他相關(guān)操作之后再釋放禁用。
 doSomeThing()
 .then(() => {
  request.vm.disabled = false
 })
}

常見問題

全局onSubmit中提交了請求,返回了請求。這些操作如何通知到對應(yīng)的組件?

Request對象中有一個vm屬性,這是hookForm組件本身的vue實例。父子組件通信
也就是說hookForm只是扮演form和ajax之間的橋梁,負(fù)責(zé)傳送一下form表單數(shù)據(jù)。你可以基于它二次封裝一個更多功能的form組件

全局hook和局部hook會不會同時觸發(fā)?

不會。如果存在局部hook,那么優(yōu)先觸發(fā)局部,否則才觸發(fā)全局。

以上是“vue-hook-form怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

標(biāo)題名稱:vue-hook-form怎么用
URL鏈接:http://jinyejixie.com/article6/psphog.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、標(biāo)簽優(yōu)化、App設(shè)計、網(wǎng)站設(shè)計、網(wǎng)站排名、靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)