鍍金池/ 問答/HTML/ iviewui中使用表單組件的動態(tài)增減表單項,如何設置表單驗證?

iviewui中使用表單組件的動態(tài)增減表單項,如何設置表單驗證?

動態(tài)增減表單項在這個列子中,:rules="{required: true, message: 'Item ' + item.index +' can not be empty', trigger: 'blur'}"這樣的設置的表單驗證是能正常驗證的,在此驗證規(guī)則上修改設置required: falsetype: 'number'、max: 200這些,也是能驗證的,但怎么在動態(tài)的表單中的某一個輸入項上設置多個驗證規(guī)則?

若想要驗證輸入的數(shù)字是0到100,可以是負數(shù),小數(shù)保留1位,這種動態(tài)增減表單項的如何寫驗證?
該怎么像固定表單 <Form ref="info" :model="baseInfo" :rules="infoValidate" :label-width="200" class="authentication-form">"這樣子自定義:rules="infoValidate"呢?

回答
編輯回答
墻頭草

rules 放一個數(shù)組可以嗎。當然有一個一定可以的方法,就是 :rules="{validator: validateInput, trigger: 'blur'}" 然后在 data 里面聲明一個 validateInput 方法,具體可以參照 iview 的自定義驗證。

2018年1月16日 14:39
編輯回答
我甘愿

建議從計算屬性的角度解決問題

2017年5月23日 21:31
編輯回答
青瓷

這種非常規(guī)的校驗規(guī)則,建議直接寫自定義驗證

<template>
    <Form ref="formCustom" :model="formCustom" :rules="ruleCustom" :label-width="80">
        <FormItem label="Password" prop="passwd">
            <Input type="password" v-model="formCustom.passwd"></Input>
        </FormItem>
        <FormItem label="Confirm" prop="passwdCheck">
            <Input type="password" v-model="formCustom.passwdCheck"></Input>
        </FormItem>
        <FormItem label="Age" prop="age">
            <Input type="text" v-model="formCustom.age" number></Input>
        </FormItem>
        <FormItem>
            <Button type="primary" @click="handleSubmit('formCustom')">Submit</Button>
            <Button @click="handleReset('formCustom')" style="margin-left: 8px">Reset</Button>
        </FormItem>
    </Form>
</template>
<script>
    export default {
        data () {
            const validatePass = (rule, value, callback) => {
                if (value === '') {
                    callback(new Error('Please enter your password'));
                } else {
                    if (this.formCustom.passwdCheck !== '') {
                        // 對第二個密碼框單獨驗證
                        this.$refs.formCustom.validateField('passwdCheck');
                    }
                    callback();
                }
            };
            const validatePassCheck = (rule, value, callback) => {
                if (value === '') {
                    callback(new Error('Please enter your password again'));
                } else if (value !== this.formCustom.passwd) {
                    callback(new Error('The two input passwords do not match!'));
                } else {
                    callback();
                }
            };
            const validateAge = (rule, value, callback) => {
                if (!value) {
                    return callback(new Error('Age cannot be empty'));
                }
                // 模擬異步驗證效果
                setTimeout(() => {
                    if (!Number.isInteger(value)) {
                        callback(new Error('Please enter a numeric value'));
                    } else {
                        if (value < 18) {
                            callback(new Error('Must be over 18 years of age'));
                        } else {
                            callback();
                        }
                    }
                }, 1000);
            };
            
            return {
                formCustom: {
                    passwd: '',
                    passwdCheck: '',
                    age: ''
                },
                ruleCustom: {
                    passwd: [
                        { validator: validatePass, trigger: 'blur' }
                    ],
                    passwdCheck: [
                        { validator: validatePassCheck, trigger: 'blur' }
                    ],
                    age: [
                        { validator: validateAge, trigger: 'blur' }
                    ]
                }
            }
        },
        methods: {
            handleSubmit (name) {
                this.$refs[name].validate((valid) => {
                    if (valid) {
                        this.$Message.success('Success!');
                    } else {
                        this.$Message.error('Fail!');
                    }
                })
            },
            handleReset (name) {
                this.$refs[name].resetFields();
            }
        }
    }
</script>
2017年11月5日 04:45
編輯回答
尕筱澄

首先,感謝大家的回答。

動態(tài)增減表單項的自定義驗證試過了,沒成功,可能是我哪里寫錯了。

后來仔細查看文檔,發(fā)現(xiàn)pattern ,驗證規(guī)則rules可以直接設置正則pattern:/^((\d\d(.\d)?)|100)$/,例如:

<FormItem :label="'分數(shù):'" 
          :prop="'items.' + index + '.score'+item.index"
          :rules="{pattern:/^((\d\d(.\d)?)|100)$/, message: '請輸入數(shù)值為0~100,小數(shù)點后保留1位', trigger: 'blur'}"> 
     <Input type="text" v-model="item['score'+ item.index]" placeholder="請輸入分數(shù)"></Input>
</FormItem>
2017年7月4日 07:43