大飞_dafei

导航

ant-design-vue 之form表单使用

ant-design-vue 之form表单使用

主要代码: v-decorator, setFieldsValue, getFieldsValue, resetFields, validateFields

this.form.setFieldsValue({"username":['username_ddddd'],"nickname":['nickname_ddddd']}); //设置值   
this.form.setFieldsValue({"username": 'username_ddddd', "nickname": 'nickname_ddddd'}); //设置值

this.form.getFieldsValue();// 获取所有值
this.form.getFieldsValue(['username','nickname']); // 获取某一个值

this.form.resetFields();  // 重置表单值

this.form.validateFields((err,fieldsValue) => {  // 校验所有的值
  if (!err) {
    console.log(fieldsValue); //获取数据 {nickname: "实际值", username: "实际值"}
  }else {
    console.log(err);
  }
});

this.form.validateFields(['nickname'],(err,fieldsValue)=>{ // 校验某个值
  if (!err) {
    console.log(fieldsValue); //获取数据 {nickname: "实际值"}
  }else {
    console.log(err);
  }
});

 

  

 

demo 练习

<template>
    <div>
        <a-form :form="form">

            <a-form-item label="Name">
                <a-input placeholder="Please input your name"
                         v-decorator="username" />
            </a-form-item>

            <a-form-item  label="Nickname">
                <a-input  placeholder="Please input your nickname"
                          v-decorator="['nickname',{ rules: [{ required: true, message: 'Please input your nickname' }] },]"/>
            </a-form-item>

            <button @click="fei_form">form功能测试</button>
        </a-form>
    </div>
</template>
<script>

/* 这是ant-design-vue */
import Vue from 'vue'
import Antd, { message,Select } from 'ant-design-vue'  //这是ant-design-vue
import 'ant-design-vue/dist/antd.css'
Vue.use(Antd);
/* 这是ant-design-vue */


export default {
    data() {
        return {
            form: this.$form.createForm(this, { name: 'form_rule' }), // 定义form
            username: ['username', {rules: [{required: true, message: 'Please input your username'}]}]
        }
    },
    methods: {

        fei_form() {

            this.form.setFieldsValue({"username":['username_ddddd'],"nickname":['nickname_ddddd']}); //设置值

            this.form.getFieldsValue();// 获取所有值
            this.form.getFieldsValue(['username','nickname']); // 获取某一个值

            this.form.resetFields();  // 重置表单值

            this.form.validateFields((err,fieldsValue) => {  // 校验所有的值
                if (!err) {
                    console.log(fieldsValue); //获取数据 {nickname: "实际值", username: "实际值"}
                }else {
                    console.log(err);
                }
            });

            this.form.validateFields(['nickname'],(err,fieldsValue)=>{ // 校验某个值
                if (!err) {
                    console.log(fieldsValue); //获取数据  {nickname: "实际值"}
                }else {
                    console.log(err);
                }
            });

        }
    },
    watch: {

    },
};
</script>

<style scoped>

</style>

setFields 设置一组输入控件的值与错误状态 

this.form.setFields({
    "username": {
        value: "xxx_可以给一个默认值",
        errors: [{"message": "请选择输入用户名"}]
    }
});

 

长度校验

export default {
    data() {
        return {
            form: this.$form.createForm(this, { name: 'form_rule' }), // 定义form
            // username: ['username', {rules: [{required: true, message: 'Please input your username'}]}],
            username: ['username', {
                initialValue: '', // 默认值
                rules: [
                    {required: true, message: 'Please input your username'}, // 必填校验
                    {type: 'string', message: '最大长度50', max:50,}, // 长度校验
                ]
        }],
        }
    },
}

 

 

 

 

 

Form 表单

 

posted on 2020-08-03 10:34  大飞_dafei  阅读(8114)  评论(0编辑  收藏  举报