本文针对知乎上关于Vue.js如何优雅的进行form validation问题进行了整理,供大家参考,具体内容如下

Vue.js如何优雅的进行form validation?
1. 所有validation rules是被集中管理,而不是每个文件自己一种,导致验证规则冗余。
2. 能够进行remote validate。
3. 不用JQuery。
现有的插件vuejs/vue-validator · GitHub只能实现普通验证,但如何解决1,因为vue-validator没有把校验规则给抽象出来,没办法,现在只能自己代码上再抽出一层rules来管理。remote validation只能手写借助Jquery ajax来验证。
网友1、曾广营
这个现在我可以回答了。
我觉得 vue-validator 太冗余了。所以自己写了个项目用的插件 va.js,它实现了
集中式的管理 校验规则 和 报错模板。
报错时机可选
校验正确后的数据,已经打包成对象,可以直接用
允许各个页面对规则进行覆盖,对报错信息进行自定义修改,以及允许ajax获取数据后,再对规则进行补充
按顺序来校验报错
我写了一篇博文来记载
va.js的写作历程。va.js——Vue 表单验证插件的写作过程
我个人观点。表单验证的是一种高度定制化的东东。所以网上用的插件,都会有不尽人意的感觉,因为要么冗余,要么不够。因此,我分享了思路和源码。真的想写的话,借鉴思路自己写吧。
补充:
1.自定义的js函数规则,可以自己再加入。 有个存储校验函数的对象,可以扩展。
2.对ajax的处理仅仅是暴露通过校验的数据的对象。即假如在ajax前不需验证的话,这份暴露出来的数据是可以提交的;假如需要验证,可以使用这个暴露出来的数据,对单个或多个字段加上额外的校验。
网友2、冉聪杰
推荐:vee-validate https://github.com/logaretm/vee-validate/
网友3、李文富
自己简单写一个,支持异步,支持任意 Vue Component,不限定于 Form Element。
来自:https://github.com/crossjs/plato/blob/master/src/modules/validator/index.js
看 return 部分即可:
import Vue from 'vue'
import * as rules from './rules'
import promisify from 'util/promisify'
export default (context, options = {}) => {
// options = { scope: 'validator', prefix: '/', ...options }
// 只注册回调,不注册数据
return () => {
Vue.mixin({
beforeCreate () {
const options = this.$options
const { validator } = options
if (validator) {
// 在入口处定义 $validation
Vue.util.defineReactive(this, '$validation', {
fields: [],
errors: []
})
this.$validator = this
nextTick(this, validator.auto)
} else {
const { parent } = options
if (parent && parent.$validation) {
this.$validation = parent.$validation
this.$validator = parent.$validator
nextTick(this, parent.$validator.$options.validator.auto)
}
}
}
})
/**
* $validate
*
* validate vm recursively.
*
* @return {Promise}
*/
Vue.prototype.$validate = function (fromEntry) {
const { validate, $validation = {}, $validator } = this
// 如果此处为校验入口
if ($validator === this && !fromEntry) {
// 顶级往下校验所有子组件
return Promise.all($validation.fields
.map(field => field.$validate(true)))
.then(() => $validation)
.catch(() => Promise.reject($validation))
} else {
if (!validate) {
return Promise.resolve($validation)
}
return Promise.all(Object.keys(validate).map(key => {
return new Promise((resolve, reject) => {
const { validator = rules[key], rule, message } = validate[key]
if (validator) {
// reject if falsy
promisify(validator(this.value, rule), true)
.then(resolve)
.catch(() => {
reject({
field: this.field || this,
rule,
message
})
})
} else {
__PROD__ || console.warn(`'${key}' is NOT a valid validator`)
resolve()
}
})
})).then(() => {
updateErrors($validation.errors, this)
return $validation
}).catch(error => {
updateErrors($validation.errors, this, error)
return Promise.reject($validation)
})
}
}
function updateErrors (errors, vm, replacement) {
const field = vm.field || vm
const found = errors.some((error, index) => {
if (error.field === field) {
if (replacement) {
errors.splice(index, 1, replacement)
} else {
errors.splice(index, 1)
}
return true
}
return false
})
if (!found && replacement) {
errors.push(replacement)
}
return errors
}
function nextTick (vm, auto) {
vm.$nextTick(() => {
// 定义了校验规则
if (vm.validate) {
vm.$validation.fields.push(vm)
// 加载完成自动检查
if (auto) {
vm.$validate()
}
}
})
}
}
}
还有一个网友推荐的:试试这个自带气泡提示的vue校验插件,配合vue-hook-form能够轻松实现表单校验
以上就是整理的关于此类问题的几个不错的回答,如果大家有更好的答案欢迎分享,希望本文对大家的学习有所帮助,也希望大家多多支持。
# Vue.js
# form
# validation
# 最适应的vue.js的form提交涉及多种插件【推荐】
# 报错
# 表单
# 写了
# 自定义
# 的是
# 几个
# 会有
# 有个
# 我觉得
# 多个
# 没办法
# 不尽人意
# 这份
# 此类
# 还有一个
# 仅仅是
# 可以直接
# 可选
# 个人观点
# 不需
相关文章:
制作网站外包平台,自动化接单网站有哪些?
深入理解Android中的xmlns:tools属性
如何通过网站建站时间优化SEO与用户体验?
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
如何配置IIS站点权限与局域网访问?
如何在阿里云ECS服务器部署织梦CMS网站?
如何选择高性价比服务器搭建个人网站?
如何在建站宝盒中设置产品搜索功能?
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
如何在云主机快速搭建网站站点?
西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?
南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?
已有域名建站全流程解析:网站搭建步骤与建站工具选择
北京网站制作公司哪家好一点,北京租房网站有哪些?
Android使用GridView实现日历的简单功能
微信推文制作网站有哪些,怎么做微信推文,急?
网站设计制作企业有哪些,抖音官网主页怎么设置?
婚礼视频制作网站,学习*后期制作的网站有哪些?
如何用狗爹虚拟主机快速搭建网站?
如何快速搭建个人网站并优化SEO?
学校免费自助建站系统:智能生成+拖拽设计+多端适配
网站制作大概多少钱一个,做一个平台网站大概多少钱?
陕西网站制作公司有哪些,陕西凌云电器有限公司官网?
小型网站建站如何选择虚拟主机?
如何快速选择适合个人网站的云服务器配置?
如何在云主机上快速搭建多站点网站?
建站之星北京办公室:智能建站系统与小程序生成方案解析
建站主机如何选?性能与价格怎样平衡?
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
如何在新浪SAE免费搭建个人博客?
如何通过VPS建站实现广告与增值服务盈利?
建站OpenVZ教程与优化策略:配置指南与性能提升
如何快速建站并高效导出源代码?
建站之星体验版:智能建站系统+响应式设计,多端适配快速建站
北京网站制作的公司有哪些,北京白云观官方网站?
高防服务器租用指南:配置选择与快速部署攻略
营销式网站制作方案,销售哪个网站招聘效果最好?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
,交易猫的商品怎么发布到网站上去?
html制作网站的步骤有哪些,iapp如何添加网页?
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?
郑州企业网站制作公司,郑州招聘网站有哪些?
外贸公司网站制作哪家好,maersk船公司官网?
建站之星后台密码如何安全设置与找回?
如何解决ASP生成WAP建站中文乱码问题?
如何实现建站之星域名转发设置?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
Swift中swift中的switch 语句
*请认真填写需求信息,我们会在24小时内与您取得联系。