mirror of
https://github.com/tusen-ai/naive-ui.git
synced 2025-01-06 12:17:13 +08:00
3.3 KiB
3.3 KiB
自定义规则
有时候内置的 trigger 无法满足验证的需要。你可以通过设定自定的 trigger 然后手动触发它来控制验证。
<n-form
:model="model"
ref="form"
:rules="rules"
>
<n-form-item-row
path="age"
label="年龄"
>
<n-input
v-model:value="model.age"
@keydown.enter.prevent
/>
</n-form-item-row>
<n-form-item-row
path="password"
label="密码"
>
<n-input
v-model:value="model.password"
@input="handlePasswordInput"
type="password"
@keydown.enter.prevent
/>
</n-form-item-row>
<n-form-item-row
first
path="reenteredPassword"
label="重复密码"
ref="reenteredPassword"
>
<n-input
:disabled="!model.password"
v-model:value="model.reenteredPassword"
type="password"
@keydown.enter.prevent
/>
</n-form-item-row>
<n-row :gutter="[0, 24]">
<n-col :span="24">
<div style="display: flex; justify-content: flex-end;">
<n-button
@click="handleValidateButtonClick"
:disabled="model.age === null"
round
type="primary"
>
验证
</n-button>
</div>
</n-col>
</n-row>
</n-form>
<pre>
{{ JSON.stringify(model, 0, 2) }}
</pre>
export default {
inject: ['message'],
data () {
return {
model: {
age: null,
password: null,
reenteredPassword: null
},
rules: {
age: [
{
required: true,
validator (rule, value) {
if (!value) {
return new Error('需要年龄')
} else if (!/^\d*$/.test(value)) {
return new Error('年龄应该为整数')
} else if (Number(value) < 18) {
return new Error('年龄应该超过十八岁')
}
return true
},
trigger: ['input', 'blur']
}
],
password: [
{
required: true,
message: '请输入密码'
}
],
reenteredPassword: [
{
required: true,
message: '请再次输入密码',
trigger: ['input', 'blur']
},
{
validator: this.validatePasswordStartWith,
message: '两次密码输入不一致',
trigger: 'input'
},
{
validator: this.validatePasswordSame,
message: '两次密码输入不一致',
trigger: ['blur', 'password-input']
}
]
}
}
},
methods: {
handlePasswordInput () {
if (this.model.reenteredPassword) {
this.$refs.reenteredPassword.validate({ trigger: 'password-input' })
}
},
handleValidateButtonClick (e) {
e.preventDefault()
this.$refs.form.validate(errors => {
if (!errors) {
this.message.success('验证成功')
} else {
console.log(errors)
this.message.error('验证失败')
}
})
},
validatePasswordStartWith (rule, value) {
return this.model.password && this.model.password.startsWith(value) && this.model.password.length >= value.length
},
validatePasswordSame (rule, value) {
return value === this.model.password
}
}
}