UNPKG

cloud-ui.vusion

Version:
268 lines (230 loc) 9.06 kB
### 规则列表 每个表单项的验证行为用一个有序列表`rules`来声明,列表中包含若干条验证规则。结构如下: ``` javascript [{ type: 'string', required: true, ... }, { type: 'string', min: ... }, { type: 'string', pattern: ... }, ...] ``` 每条规则至少包含以下几个参数: - `type`:数据类型 - `trigger`:触发方式 - `message`:验证不通过时的消息提示 - ... 下面举个例子,一个用户名输入框的验证包含以下规则: 1. 必须输入用户名,失焦验证 2. 以字母开头,实时验证 3. 字母、数字或中划线组成,实时验证 4. 以字母或数字结尾,失焦验证 5. 4~12个字符,失焦验证 ``` vue <template> <u-form-item label="用户名" :rules="rules"> <u-input size="huge" maxlength="112" placeholder="4~12位字母、数字或中划线组成"></u-input> </u-form-item> </template> <script> export default { data() { return { rules: [ { type: 'string', required: true, trigger: 'blur', message: '请输入用户名' }, { type: 'string', pattern: /^[a-zA-Z]/, trigger: 'input+blur', message: '以字母开头' }, { type: 'string', pattern: /^[a-zA-Z0-9-]+$/, trigger: 'input+blur', message: '字母、数字或中划线组成' }, { type: 'string', pattern: /[a-zA-Z0-9]$/, trigger: 'blur', message: '以字母或数字结尾' }, { type: 'string', min: 4, trigger: 'blur', message: '不得少于4个字符' }, ], }; }, }; </script> ``` #### 多字段的规则列表 如果一个表单多个字段有规则列表,可以在`u-form`中汇总传入。 ``` vue <template> <u-form ref="form" gap="large" :rules="rules"> <u-form-item label="用户名" name="username"> <u-input size="huge" maxlength="12" placeholder="4~12个字符"></u-input> </u-form-item> <u-form-item label="邮箱" name="email"> <u-input size="huge" maxlength="24" placeholder="请输入邮箱"></u-input> </u-form-item> </u-form> </template> <script> export default { data() { return { rules: { username: [ { type: 'string', required: true, trigger: 'blur', message: '请输入用户名' }, { type: 'string', min: 4, max: 12, trigger: 'blur', message: '请输入4~12个字符' }, ], email: [ { type: 'string', required: true, trigger: 'blur', message: '请输入邮箱' }, { type: 'email', trigger: 'blur', message: '邮箱格式不正确' }, ], }, }; }, }; </script> ``` ### 数据类型 - `string`: Must be of type string. This is the default type. - `number`: Must be of type number. - `boolean`: Must be of type boolean. - `method`: Must be of type function. - `regexp`: Must be an instance of RegExp or a string that does not generate an exception when creating a new RegExp. - `integer`: Must be of type number and an integer. - `float`: Must be of type number and a floating point number. - `array`: Must be an array as determined by Array.isArray. - `object`: Must be of type object and not Array.isArray. - `enum`: Value must exist in the enum. - `date`: Value must be valid as determined by Date - `url`: Must be of type url. - `hex`: Must be of type hex. - `email`: Must be of type email. 其它请参见[async-validator](https://github.com/yiminghe/async-validator)。 ### 触发方式 表单验证行为按照实时性通常可以分为三种:提交验证、失焦验证、实时验证,分别对应验证规则`trigger`的三种触发方式:`submit`, `blur`, `input`,规则中默认为`submit`。 另外还有一种行为叫表单限制,不属于表单验证,但通常与之配合使用。 #### 提交验证 点击表单提交按钮时才对表单中所有控件进行验证,通常对应submit按钮的`click`事件。示例如下: ``` vue <template> <u-form ref="form" gap="large" :rules="rules"> <u-form-item label="用户名" name="username"> <u-input size="huge" maxlength="12" placeholder="4~12个字符"></u-input> </u-form-item> <u-form-item label="邮箱" name="email"> <u-input size="huge" maxlength="24" placeholder="请输入邮箱"></u-input> </u-form-item> <u-form-item> <u-button color="primary" @click="submit()">提交</u-button> </u-form-item> </u-form> </template> <script> export default { data() { return { rules: { username: [ { type: 'string', required: true, message: '请输入用户名' }, { type: 'string', min: 4, max: 12, message: '请输入4~12个字符' }, ], email: [ { type: 'string', required: true, message: '请输入邮箱' }, { type: 'email', message: '邮箱格式不正确' }, ], }, }; }, methods: { async submit() { const result = await this.$refs.form.validate(); if (result.valid) alert('提交成功'); }, }, }; </script> ``` #### 失焦验证 在表单控件失去焦点时对该控件进行验证,通常对应表单控件的`blur`事件。示例如下: ``` vue <template> <u-form ref="form" gap="large" :rules="rules"> <u-form-item label="用户名" name="username"> <u-input size="huge" maxlength="12" placeholder="4~12个字符"></u-input> </u-form-item> <u-form-item label="邮箱" name="email"> <u-input size="huge" maxlength="24" placeholder="请输入邮箱"></u-input> </u-form-item> </u-form> </template> <script> export default { data() { return { rules: { username: [ { type: 'string', required: true, trigger: 'blur', message: '请输入用户名' }, { type: 'string', min: 4, max: 12, trigger: 'blur', message: '请输入4~12个字符' }, ], email: [ { type: 'string', required: true, trigger: 'blur', message: '请输入邮箱' }, { type: 'email', trigger: 'blur', message: '邮箱格式不正确' }, ], }, }; }, }; </script> ``` #### 实时验证 在表单控件的值实时输入改变时,对该控件进行验证,通常对应表单的`input`事件。当只激活实时验证时,失焦验证会跳过此规则并且覆盖原来的结果,因此通常我们需要采用实时与失焦叠加的方式`input+blur`。 下面的例子中,对用户名长度和邮箱格式的判断为实时验证。其中邮箱的验证没有采用实时与失焦叠加的方式,可以发现这种方式不是很合理。 ``` vue <template> <u-form ref="form" gap="large" :rules="rules"> <u-form-item label="用户名" name="username"> <u-input size="huge" maxlength="12" placeholder="4~12个字符"></u-input> </u-form-item> <u-form-item label="邮箱" name="email"> <u-input size="huge" maxlength="24" placeholder="请输入邮箱"></u-input> </u-form-item> </u-form> </template> <script> export default { data() { return { rules: { username: [ { type: 'string', required: true, trigger: 'blur', message: '请输入用户名' }, { type: 'string', min: 4, max: 12, trigger: 'input+blur', message: '请输入4~12个字符' }, ], email: [ { type: 'string', required: true, trigger: 'blur', message: '请输入邮箱' }, { type: 'email', trigger: 'input', message: '邮箱格式不正确' }, ], }, }; }, }; </script> ``` #### 表单限制 在表单控件的值改变时,对该值限制在规定的长度或范围内,如`<input>`控件的部分`type`和`maxlength`的限制行为等: ``` html <u-form gap="large"> <u-form-item label="用户名"> <u-input size="huge" maxlength="4" placeholder="不超过4个字符"></u-input> </u-form-item> </u-form> ``` ### 验证提示 `<u-form-item>`的`message`属性用于设置默认提示,规则中的`message`字段用于设置验证不通过时提示。 ``` vue <template> <u-form ref="form" :rules="rules"> <u-form-item label="用户名" name="username" message="用户名是唯一的"> <u-input maxlength="12" placeholder="4~12个字符"></u-input> </u-form-item> </u-form> </template> <script> export default { data() { return { rules: { username: [ { type: 'string', required: true, trigger: 'blur', message: '请输入用户名' }, { type: 'string', min: 4, max: 12, trigger: 'blur', message: '请输入4~12个字符' }, ], }, }; }, }; </script> ```