const forbiddenCharValidator = (rule, value, callback) => {const forbiddenCharacters = ['as', 'for', 'default', 'in', 'join', 'left', 'inner', 'right', 'where', 'when', 'case', 'select'];for (let forbiddenCharacter of forbiddenCharacters) {if (value && value.includes(forbiddenCharacter)) {callback(new Error(`不能使用关键字 '${forbiddenCharacter}'`));return;}}callback();
};
使用场景:
这个验证规则对象通常用在表单组件中,例如 Element Plus 的 <el-form>
或 <el-input>
组件,来确保用户输入的数据符合特定的要求。例如,你可能不希望用户在某些输入字段中使用特定的关键字,因为这些关键字可能是保留字或有特殊意义。
示例:
在 Vue 组件中,你可能会这样使用这个验证规则:
<template><el-form :model="form" :rules="rules"><el-form-item label="用户名" prop="username" :rules="{ validator: forbiddenCharValidator, trigger: 'blur' }"><el-input v-model="form.username"></el-input></el-form-item></el-form>
</template><script>
export default {data() {return {form: {username: ''},rules: {username: [{ validator: forbiddenCharValidator, trigger: 'blur' }]}};},methods: {forbiddenCharValidator(rule, value, callback) {// 自定义验证逻辑}}
};
</script>