【21】vuex 与element iu表单校验
2024-08-24 06:40:33
转:http://www.cnblogs.com/gsgs/p/6753682.html
element-ui的官网上写的自定义表单验证,方法都是写在单vue文件中的,不容易共享。怎么使用vuex将方法共享出来,各个组件都能用呢?
如下是一个验证age的数据,
rules:{
age:[{required:true,trigger:'blur',validator:checkAge}]
}
required:true 指提示必须要填,也就是input那个红色星星,必填的标志,对数据是不影响的。
trigger:‘blur’,当失去焦点就进行一次验证。
validator:checkAge 我这儿我定义了一个checkAge函数,写在data中return的前面。这个其实只是个传参函数
思路:当失去焦点,会使validator验证会调用一次checkAge函数。并且会给checkAge默认传参数,checkAge(rules,value,callback){},value是input框中的内容,callback是回调函数。这3个参数是关键,必须要传给vuex store中的验证函数。
这儿要提醒一点:store中传过来的共享方法,并不是实实在在的方法,不管是map或者dispatck出来的,都不是原始方法,也就是说,不能如下这么干:
methods:map['checkAge'],
mounted(){
this.rules.age[0].validator=this.checkAge //这样出错,这个checkAge不是正常的方法,被包装过。如果是state数据是可以直接这样干的。
}
因此,写一个转换函数:
data(){
let checkAge=(rules,value,callback)=>{ //转换函数,主要目的是传给store内方法的参数。
this.$store.dispatch('checkAge',{rules,value,callback})//这儿的checkAge是写在store中的,vuex规定参数必须传对象。
}
return {
rules:{
age:[{required:true,trigger:'blur',validator:checkAge}]//主要格式是标准json。
},
msg:{
age:''
}
}
}
剩下的只需要在store中的actions内写上验证方法就行了。
//store中写:
let actions = {
checkAge({ commit }, obj) {//这个obj就是需要的参数,这个blur事件经过validator包装后的参数。随后的就跟官网上的一样了,随意写。
if (!obj.value) {
obj.cb(new Error('年龄不能为空'))
} else if (typeof obj.value != 'number') {
obj.cb(new Error('年龄必须为数字'))
} else {
if (obj.value > 100) {
obj.cb(new Error("年龄要打破记录了"))
} else if (obj.value < 0) {
obj.cb(new Error('年龄小了点,无法接受'))
} else {
obj.cb()
}
}
commit('dd')
}
}
let mutations={
dd(){}
}
export default new Vuex.Store({
actions,
mutations
})
最新文章
- [.Net] 通过反射,给Enum加备注
- Java IO3:字符流
- LA3942-Remember the Word(Trie)
- rsync在windows和linux同步数据的配置过程
- python之简单入门01
- IOS学习【前言】
- Redis常见七种使用场景(PHP实战)
- 怎样保证socket.recv接收完数据
- 浅谈利用同步机制解决Java中的线程安全问题
- 在eclipse中安装properties插件PropertiesEditor及设置(附图),ASCII码转换成中文
- python3+selenium框架设计10-发送邮件
- java使用md5加密
- SSLv3存在严重设计缺陷漏洞(CVE-2014-3566)
- Nginx安装与使用 及在redhat 中的简单安装方式
- avalon2学习教程 03数据填充
- webkit-user-select:none 问题
- WCF使用net.tcp绑定时的注意事项
- IOS-5个可以帮你优化App的优秀网站
- HTTP协议状态码学习
- sso单点登录研究