Skip to content

管理字段ID

在表单设计器中,字段ID用于唯一标识每个组件的字段。默认情况下,字段ID是随机生成的,且用户无法输入。您可以通过以下配置自定义字段ID的输入和选择方式。

数据结构

FieldItem 定义了字段ID选择项的结构:

ts
type FieldItem = {
    //字段名
    value?: string;
    //别名
    label: string;
    //修改当前规则的必填,禁用和说明
    update?: {
        required?: Boolean;
        disabled?: Boolean;
        info?: string;
    };
    //子级字段列表
    children?: FieldItem[];
}

允许字段ID可以输入

通过设置 config.fieldReadonly 属性,您可以控制字段ID输入框是否可编辑:

vue
<template>
    <fc-designer ref="designer" :config="config"/>
</template>
<script setup>
    const config = {
        //控制字段ID输入框能否输入
        fieldReadonly: false
    }
</script>
  • fieldReadonly: true: 字段ID只能从选择项中选择,不能手动输入。
  • fieldReadonly: false: 字段ID可以手动输入或从选择项中选择。

自定义字段ID的选择项

custom-field.png

通过设置 config.fieldList 属性,您可以定义字段ID的选择项列表。选择项支持嵌套结构,便于组织和管理复杂的字段列表。

vue


<template>
    <fc-designer ref="designer" :config="config"/>
</template>
<script setup>
    const config = {
        //控制字段ID只能选择,不能输入
        fieldReadonly: true,
        fieldList: [
            {
                value: 'goods',
                label: '商品表',
                children: [
                    {
                        value: 'goods_name',
                        label: '商品名称',
                    },
                    {
                        value: 'goods_info',
                        label: '商品简介',
                    },
                    {
                        value: 'goods_cate',
                        label: '商品分类',
                    },
                ],
            },
            {
                value: 'order',
                label: '订单表',
                children: [
                    {
                        value: 'order_id',
                        label: '订单id',
                    },
                    {
                        value: 'order_sn',
                        label: '订单号',
                    },
                    {
                        value: 'order_time',
                        label: '订单时间',
                    },
                ],
            },
        ]
    }
</script>

选择字段时修改组件规则

通过 update 字段,您可以在选择字段时动态修改组件的必填、禁用和说明等规则:

vue


<template>
    <fc-designer ref="designer" :config="config"/>
</template>
<script setup>
    const config = {
        //控制字段ID只能选择,不能输入
        fieldReadonly: false,
        fieldList: [
            {
                value: 'goods',
                label: '商品表',
                children: [
                    {
                        value: 'goods_name',
                        label: '商品名称',
                        update: {
                            required: true,
                            info: '请输入商品名称',
                            dislabed: false,
                        }
                    },
                    {
                        value: 'goods_info',
                        label: '商品简介',
                    },
                    {
                        value: 'goods_cate',
                        label: '商品分类',
                        update: {
                            required: false,
                            info: '请选择商品分类',
                            dislabed: true,
                        }
                    },
                ],
            },
        ]
    }
</script>

在上述配置中,选择“商品名称”字段后,该组件会自动变为必填状态,并显示提示信息。

子表单组件与内部表单组件联动

默认情况下,当子表单组件选择的字段存在 children 时,内部的其他组件只能从 children 中选择。可以通过设置 config.relationField 来控制此功能:

vue
<template>
    <fc-designer ref="designer" :config="config"/>
</template>
<script setup>
    const config = {
        // 控制是否启用字段联动
        relationField: true // 设置为 false 以禁用字段联动
    }
</script>
  • relationField: true: 启用字段联动,子表单选择的字段会影响其他组件的选择范围。
  • relationField: false: 禁用字段联动,所有组件可以自由选择字段。

动态修改字段ID选项

除了静态设置字段ID选择项,您还可以根据业务需求动态修改字段ID选项。这在需要根据用户的选择或其他条件动态调整字段选项时特别有用。

1. 定义动态字段ID选项更新方法 在组件内部定义一个方法,用于更新字段ID选项列表。

vue
<template>
    <fc-designer ref="designer" :config="config"/>
    <button @click="updateFieldList">更新字段列表</button>
</template>
<script setup>
    import { ref } from 'vue';


const config = ref({
        fieldReadonly: false,
        fieldList: [
            // 初始字段选项
        ]
    });


// 更新字段列表的方法
    const updateFieldList = () => {
        config.value.fieldList = [
            {
                value: 'user',
                label: '用户表',
                children: [
                    { value: 'user_name', label: '用户名' },
                    { value: 'user_email', label: '用户邮箱' }
                ]
            },
            {
                value: 'product',
                label: '产品表',
                children: [
                    { value: 'product_name', label: '产品名称' },
                    { value: 'product_price', label: '产品价格' }
                ]
            }
        ];
    }
</script>

2.在用户操作时更新字段ID选项

通过用户操作或其他事件触发字段ID选项的更新。例如,可以在表单加载后从服务器获取字段ID选项,并根据业务逻辑进行更新。

vue
<template>
    <fc-designer ref="designer" :config="config"/>
</template>
<script setup>
    import { ref, onMounted } from 'vue';


const config = ref({
        fieldReadonly: false,
        fieldList: []
    });


// 获取动态字段列表的函数
    const fetchFieldList = async () => {
        // 模拟从服务器获取字段列表
        const response = await fetch('/api/fields');
        const data = await response.json();
        config.value.fieldList = data;
    }


onMounted(() => {
        fetchFieldList();
    });
</script>

这样,字段ID列表会在组件加载时从服务器获取,并且可以根据实际业务需求进行调整。