ant兼容label-in-value和field-names正常显示回显的vue方案
时间: 2023-08-10 13:08:04 浏览: 132
为了兼容 `label-in-value` 和 `field-names`,可以使用 `Ant Design Vue` 中的 `ASelect` 组件和 `AForm` 组件。
首先,在 `AForm` 中使用 `:model` 属性绑定数据对象,然后在 `ASelect` 中使用 `v-model` 属性绑定选中的值。同时,为了支持 `label-in-value`,需要设置 `:value-key` 属性为选项对象中的键名。
示例代码如下:
```vue
<template>
<a-form :model="formData">
<a-form-item label="选项">
<a-select v-model="formData.selectValue" :options="options" :value-key="'value'" />
</a-form-item>
</a-form>
</template>
<script>
export default {
data() {
return {
formData: {
selectValue: '',
},
options: [
{ label: '选项1', value: 'option1' },
{ label: '选项2', value: 'option2' },
],
};
},
};
</script>
```
如果要支持 `field-names`,则需要在 `AForm` 中设置 `:name` 属性,并且在 `ASelect` 中设置 `name` 属性和 `:field-name` 属性,将选项对象中的键名映射到数据对象中的键名。
示例代码如下:
```vue
<template>
<a-form :model="formData" :name="formName">
<a-form-item label="选项" :name="fieldName">
<a-select v-model="formData.selectValue" :options="options" :value-key="'value'" name="selectValue" :field-name="fieldName" />
</a-form-item>
</a-form>
</template>
<script>
export default {
data() {
return {
formData: {
selectValue: '',
},
formName: 'myForm',
fieldName: 'selectValue',
options: [
{ label: '选项1', value: 'option1' },
{ label: '选项2', value: 'option2' },
],
};
},
};
</script>
```
注意,为了支持 `field-names`,需要在选项对象中设置与数据对象中键名相同的键名。以上示例中,选项对象中的键名为 `value`,与数据对象中的键名 `selectValue` 相同。
阅读全文
相关推荐
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/4ab4e/4ab4e16af55d61505c6ba78cf12ec100586fa6ad" alt="7z"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"