vue-hook-form使用详解


Posted in Javascript onApril 07, 2017

vue-hook-form

用于处理form请求,获取formData。以便于将form请求转成ajax/fetch请求

安装

npm install vue-hook-form

使用

VUE版本:1.x
必须在vue-cli生成的webpack模板环境中使用

一、注册&配置组件

// 这里使用在main.js中全局注册来示例
import vue from 'vue'
import hookForm from 'vue-hook-form'
// 配置全局form表单序列化之前的hook
hookForm.beforeSerialize = (vm, next) => {
 // vm: 对应的hookForm vm实例
 // next:继续执行
 // 你可以在此处执行表单校验
}
// 配置全局form提交前的hook
hookForm.onSubmit = request => {
 // request:包含了本次请求的基本信息
 // 你可以在此处执行表单校验或使用ajax来提交本次请求
}
vue.component('hook-form', hookForm)

Request对象:

{
 url: '请求地址',
 body: '请求参数',
 method: '请求方法',
 vm: '对应的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:继续执行
  // 你可以在此处执行表单校验
  },
  onSubmit (request) {
  // request:包含了本次请求的基本信息
  // 你可以在此处执行表单校验或使用ajax来提交本次请求
  }
 }
 }
</script>

配置

onSubmit

form提交前的全局hook。

beforeSerialize

form表单序列化之前的全局hook。一般用于校验表单,但此时无须form表单序列化的时候。也便于在触发onSubmit之前更改form表单内容

json

Request.body是否转成json格式,默认为url字符串。默认: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:请求方法。默认:post
onSubmit:form提交前的局部hook
beforeSerialize: form表单序列化之前的局部hook
json:Request.body是否转成json格式(优先使用局部json配置)。默认:false
disabled:禁用

关于disabled

你可以通过使用该选项来防止form的多次提交

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

常见问题

全局onSubmit中提交了请求,返回了请求。这些操作如何通知到对应的组件?

Request对象中有一个vm属性,这是hookForm组件本身的vue实例。父子组件通信
也就是说hookForm只是扮演form和ajax之间的桥梁,负责传送一下form表单数据。你可以基于它二次封装一个更多功能的form组件

全局hook和局部hook会不会同时触发?

不会。如果存在局部hook,那么优先触发局部,否则才触发全局。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
封装了一个js图片轮换效果的函数
Sep 28 Javascript
浏览器窗口加载和大小改变事件示例
Feb 27 Javascript
Bootstrap Metronic完全响应式管理模板学习笔记
Jul 08 Javascript
详解angular用$sce服务来过滤HTML标签
Apr 11 Javascript
微信小程序微信支付接入开发实例详解
Apr 12 Javascript
javascript 判断一个对象为数组的方法
May 03 Javascript
JS实现弹出下载对话框及常见文件类型的下载
Jul 13 Javascript
vue 属性拦截实现双向绑定的实例代码
Oct 24 Javascript
JS复杂判断的更优雅写法代码详解
Nov 07 Javascript
vue-router两种模式区别及使用注意事项详解
Aug 01 Javascript
小程序websocket心跳库(websocket-heartbeat-miniprogram)
Feb 23 Javascript
ES6实现的遍历目录函数示例
Apr 07 #Javascript
如何使用vuejs实现更好的Form validation?
Apr 07 #Javascript
JS实现css hover操作的方法示例
Apr 07 #Javascript
微信小程序 chooseImage选择图片或者拍照
Apr 07 #Javascript
微信小程序page的生命周期和音频播放及监听实例详解
Apr 07 #Javascript
JavaScript使用链式方法封装jQuery中CSS()方法示例
Apr 07 #jQuery
jQuery中map函数的两种方式
Apr 07 #jQuery
You might like
精美漂亮的php分页类代码
2013/04/02 PHP
如何取得中文字符串中出现次数最多的子串
2013/08/08 PHP
php上传图片存入数据库示例分享
2014/03/11 PHP
PHP的全局错误处理详解
2016/04/25 PHP
PHP支付系统设计与典型案例分享
2016/08/02 PHP
ThinkPHP框架结合Ajax实现用户名校验功能示例
2019/07/03 PHP
jquery 简短几句代码实现给元素动态添加及获取提示信息
2011/09/01 Javascript
JavaScript实现信用卡校验方法
2015/04/07 Javascript
javascript删除元素节点removeChild()用法实例
2015/05/26 Javascript
JS实现兼容火狐及IE iframe onload属性的遮罩层隐藏及显示效果
2016/08/23 Javascript
jQuery事件对象总结
2016/10/17 Javascript
微信小程序 五星评分(包括半颗星评分)实例代码
2016/12/14 Javascript
canvas压缩图片转换成base64格式输出文件流
2017/03/09 Javascript
Vue服务端渲染和Vue浏览器端渲染的性能对比(实例PK )
2017/03/31 Javascript
node使用UEditor富文本编辑器的方法实例
2017/07/11 Javascript
Mongoose中document与object的区别示例详解
2017/09/18 Javascript
JavaScript解决浮点数计算不准确问题的方法分析
2018/07/09 Javascript
js单线程的本质 Event Loop解析
2019/10/29 Javascript
uin-app+mockjs实现本地数据模拟
2020/08/26 Javascript
[00:14]PWL:老朋友Mushi拍VLOG与中国玩家问好
2020/11/04 DOTA
Python语言技巧之三元运算符使用介绍
2013/03/04 Python
Python命令行参数解析模块optparse使用实例
2015/04/13 Python
浅析Python 中整型对象存储的位置
2016/05/16 Python
解决seaborn在pycharm中绘图不出图的问题
2018/05/24 Python
Tensorflow分类器项目自定义数据读入的实现
2019/02/05 Python
详解python中的生成器、迭代器、闭包、装饰器
2019/08/22 Python
PyCharm第一次安装及使用教程
2020/01/08 Python
Python函数__new__及__init__作用及区别解析
2020/08/31 Python
Ruby中的保护方法和私有方法与一般面向对象程序设计语言的一样吗
2013/05/01 面试题
高中考试作弊检讨书
2014/01/14 职场文书
2014组织生活会方案
2014/05/19 职场文书
工作保证书怎么写
2015/02/28 职场文书
2016春季运动会开幕词
2016/03/04 职场文书
浅谈MySQL表空间回收的正确姿势
2021/10/05 MySQL
python中tkinter复选框使用操作
2021/11/11 Python
Python自动操作神器PyAutoGUI的使用教程
2022/06/16 Python