element中对el-input 自定义验证规则
首先明确要使自定义校验生效的话,必须 prop 和 rules 的 键对应,如示例:(prop="description"在 rules 中有对应的键 )
<el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="140px" class="demo-ruleForm">
<el-form-item label="描述:" prop="description">
<el-input type="textarea" v-model="ruleForm.description" maxLengtn="128" placeholder="请输入描述"></el-input>
</el-form-item>
</el-form>
rules: {
description: [{ required: true, message: '请输入描述', trigger: 'blur' }]
}
自定义校验传入自定义参数
elementui的自定义校验不能传入自定义参数,如果想传入自定义参数的话,可以如下操作:
rules: {
description: [{
validator: (rule, value, callback) => {
this.validateType(rule, value, callback, this.params)
},
trigger: ['blur', 'change']
}]
}
this.params
相当于自定义参数,然后 this.validateType
中就可以接收到自定义的参数,并且也能对输入框的值进行校验了。
示例:验证一个输入框的值的类型,这个值的类型可能是['list', 'num', 'bool', 'str']
中的一种或多种,但如果为 list
的话就只能是 list
类型
// 数据类型有 ['list', 'num', 'bool', 'str']
// 一个输入框的数据类型的情况可能有
// 情况一:数据类型为 ['list'],那输入值的数据类型就可能都满足,就返回 true,最后将输入框中的值用 split(',')转为数组类型即可
// 情况二:数据类型为 ['num', 'bool', 'str'],那输入的值比如 12/true/'abc',用 typeof value 判断输入的数据类型
// let allTypes = ['list', 'num', 'bool', 'str']
/**
* @param {*} arr 输入框的数据类型
* @param {*} value 输入框的值
*/
function checkType (arr, value) {
if (arr.includes('list') && arr.length === 1) { // 还不确定
return true
} else {
// el-input 得到的值为字符串,所以需要处理,'1', 'true', '是', 0/1,使用 JSON.parse(value) 可以将对应类型的值转换,如果 JSON.parse('abc') 会直接报错
try {
value = JSON.parse(value)
} catch (error) {
// 字符串不做处理
}
if (['是', '否'].includes(value)) {
value = value === '是'
}
return arr.some(item => {
return (typeof value).indexOf(item) !== -1
})
}
}
console.log(checkType(['num', 'str', 'bool'], 'abc'))