2023-02-18 08:16:44 +00:00
|
|
|
<docs>
|
|
|
|
---
|
|
|
|
order: 5
|
|
|
|
title:
|
|
|
|
zh-CN: 自定义渲染
|
|
|
|
en-US: Custom
|
|
|
|
---
|
|
|
|
|
|
|
|
## zh-CN
|
|
|
|
|
|
|
|
自定义渲染每一个 Segmented Item。
|
|
|
|
|
|
|
|
## en-US
|
|
|
|
Custom each Segmented Item.
|
|
|
|
</docs>
|
|
|
|
<template>
|
2023-02-19 16:05:54 +00:00
|
|
|
<a-segmented v-model:value="value" :options="data">
|
|
|
|
<template #label="{ value: val, payload = {} }">
|
|
|
|
<div style="padding: 4px 4px">
|
|
|
|
<template v-if="payload.icon">
|
|
|
|
<a-avatar :src="payload.src" :style="payload.style">
|
|
|
|
<template #icon><component :is="payload.icon" /></template>
|
|
|
|
{{ payload.content }}
|
2023-02-18 08:16:44 +00:00
|
|
|
</a-avatar>
|
2023-02-19 16:05:54 +00:00
|
|
|
</template>
|
|
|
|
<template v-else>
|
|
|
|
<a-avatar :src="payload.src" :style="payload.style">
|
|
|
|
{{ payload.content }}
|
|
|
|
</a-avatar>
|
|
|
|
</template>
|
|
|
|
<div>{{ val }}</div>
|
|
|
|
</div>
|
2023-02-18 08:16:44 +00:00
|
|
|
</template>
|
|
|
|
</a-segmented>
|
|
|
|
<br />
|
|
|
|
<br />
|
2023-02-19 16:05:54 +00:00
|
|
|
<a-segmented v-model:value="value2" :options="options2">
|
|
|
|
<template #label="{ payload }">
|
|
|
|
<div style="padding: 4px 4px">
|
|
|
|
<div>{{ payload.title }}</div>
|
|
|
|
<div>{{ payload.subTitle }}</div>
|
|
|
|
</div>
|
2023-02-18 08:16:44 +00:00
|
|
|
</template>
|
|
|
|
</a-segmented>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script lang="ts">
|
2023-02-19 16:05:54 +00:00
|
|
|
import { defineComponent, ref } from 'vue';
|
2023-02-18 08:16:44 +00:00
|
|
|
import { UserOutlined } from '@ant-design/icons-vue';
|
|
|
|
import ASegmented from 'ant-design-vue/es/segmented/src/segmented';
|
|
|
|
export default defineComponent({
|
|
|
|
components: { ASegmented, UserOutlined },
|
|
|
|
setup() {
|
2023-02-19 16:05:54 +00:00
|
|
|
const data = ref([
|
|
|
|
{
|
|
|
|
value: 'user1',
|
|
|
|
payload: {
|
|
|
|
src: 'https://joeschmoe.io/api/v1/random',
|
|
|
|
style: { backgroundColor: '#f56a00' },
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
value: 'user2',
|
|
|
|
payload: {
|
|
|
|
style: { backgroundColor: '#f56a00' },
|
|
|
|
content: 'K',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
value: 'user3',
|
|
|
|
payload: {
|
|
|
|
icon: UserOutlined,
|
|
|
|
style: { backgroundColor: '#f56a00' },
|
|
|
|
},
|
|
|
|
},
|
|
|
|
]);
|
|
|
|
const options2 = ref([
|
|
|
|
{
|
|
|
|
value: 'spring',
|
|
|
|
payload: {
|
|
|
|
title: 'Spring',
|
|
|
|
subTitle: 'Jan-Mar',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
value: 'summer',
|
|
|
|
payload: {
|
|
|
|
title: 'Summer',
|
|
|
|
subTitle: 'Apr-Jun',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
value: 'autumn',
|
|
|
|
payload: {
|
|
|
|
title: 'Autumn',
|
|
|
|
subTitle: 'Jul-Sept',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
value: 'winter',
|
|
|
|
payload: {
|
|
|
|
title: 'Winter',
|
|
|
|
subTitle: 'Oct-Dec',
|
|
|
|
},
|
|
|
|
},
|
2023-02-18 08:16:44 +00:00
|
|
|
]);
|
2023-02-19 16:05:54 +00:00
|
|
|
const value = ref('user1');
|
|
|
|
const value2 = ref('spring');
|
2023-02-18 08:16:44 +00:00
|
|
|
return {
|
|
|
|
data,
|
|
|
|
options2,
|
2023-02-19 16:05:54 +00:00
|
|
|
value,
|
|
|
|
value2,
|
2023-02-18 08:16:44 +00:00
|
|
|
};
|
|
|
|
},
|
|
|
|
});
|
|
|
|
</script>
|