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,那么优先触发局部,否则才触发全局。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
基于 vue 和 element-ui 实现的表单设计器,使用了最新的前端技术栈,内置了 i18n 国际化解决方案,可以让表单开发简单而高效。 特性 可视化配置页面 提供栅格布局,支持Flex和响应式布局 一键预览配置的效果 一键生成配置json数据 一键生成代码,立即可运行 提供自定义组件满足用户自定义需求 提供远端数据接口,方便用户需要异步获取数据加载 提供功能强大的高级组件 支持表单验证 快速获取表单数据 国际化支持
项目地址 简介 Vue动态生成表单组件 可以根据数据配置表单 使用的UI库是iView 在Vue里 一般要用到什么组件或数据 都得提前声明 所以要根据数据来生成表单 只能使用Vue的render函数 要做这一个组件 其实并不难 看一下Vue官方示例 再找个UI组件库 差不多就能写出来 如果对项目有兴趣 可以fork或克隆项目 自行研究 有问题或BUG欢迎提issues 文档 在线DEMO 表单组件
vue-ele-form 是基于 element-ui form 的二次封装, 主要特点: 内置 20 多种表单类型, 包括选单选、多选、标签、级联选择器等; 拥有上传图片增强, 上传视频增强, 上传文件增强,树形下拉选择框, 富文本,表格编辑器, 动态表单, markdown, 地图, 代码编辑器, json 编辑器等丰富的第三方扩展,满足你的更多需求; 配备可视化生成表单工具; 内置表单校检;
本文向大家介绍详解Django中的form库的使用,包括了详解Django中的form库的使用的使用技巧和注意事项,需要的朋友参考一下 Django带有一个form库,称为django.forms,这个库可以处理我们本章所提到的包括HTML表单显示以及验证。 接下来我们来深入了解一下form库,并使用她来重写contact表单应用。 Django的newforms库 在Django社区上会经常看到
本文向大家介绍详解Vue使用 vue-cli 搭建项目,包括了详解Vue使用 vue-cli 搭建项目的使用技巧和注意事项,需要的朋友参考一下 vue-cli 是一个官方发布 vue.js 项目脚手架,使用 vue-cli 可以快速创建 vue 项目,GitHub地址是:https://github.com/vuejs/vue-cli 一、 安装 node.js 首先需要安装node环境,可以直
本文向大家介绍详解vue-router基本使用,包括了详解vue-router基本使用的使用技巧和注意事项,需要的朋友参考一下 路由,其实就是指向的意思,当我点击页面上的home 按钮时,页面中就要显示home的内容,如果点击页面上的about 按钮,页面中就要显示about 的内容。Home按钮 => home 内容, about按钮 => about 内容,也可以说是一种映射。 所以在页面
本文向大家介绍Jquery Easyui表单组件Form使用详解(30),包括了Jquery Easyui表单组件Form使用详解(30)的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Jquery Easyui表单组件的实现代码,供大家参考,具体内容如下 加载方式 表单组件只能在 JS 区域设置,首先定义一张表单。 属性列表 事件列表 方法列表 以上就是本文的全部内容,希望对大家的
本文向大家介绍Vue中fragment.js使用方法详解,包括了Vue中fragment.js使用方法详解的使用技巧和注意事项,需要的朋友参考一下 大部分内容源自 jQuery,当然,同时也参考了 component/domify ,如果有兴趣去这翻阅原始的代码,可以到 jQuery 中查找 wrapMap;至于 domify,直接到 github 搜索即可,相关项目类容很少,直接看 index