ant-design-vue/components/transfer/demo/custom-item.md

75 lines
1.6 KiB
Markdown
Raw Normal View History

2018-04-06 16:20:45 +00:00
<cn>
#### 自定义渲染行数据
自定义渲染每一个 Transfer Item可用于渲染复杂数据。
</cn>
<us>
#### Custom datasource
Custom each Transfer Item, and in this way you can render a complex datasource.
</us>
2019-10-09 10:32:23 +00:00
```tpl
2018-04-06 16:20:45 +00:00
<template>
<a-transfer
:dataSource="mockData"
:listStyle="{
width: '300px',
height: '300px',
}"
:targetKeys="targetKeys"
@change="handleChange"
:render="renderItem"
>
</a-transfer>
</template>
<script>
2019-09-28 12:45:07 +00:00
export default {
data() {
2018-04-06 16:20:45 +00:00
return {
2019-09-28 12:45:07 +00:00
mockData: [],
targetKeys: [],
2018-04-06 16:20:45 +00:00
};
},
2019-09-28 12:45:07 +00:00
mounted() {
this.getMock();
2018-04-06 16:20:45 +00:00
},
2019-09-28 12:45:07 +00:00
methods: {
getMock() {
const targetKeys = [];
const mockData = [];
for (let i = 0; i < 20; i++) {
const data = {
key: i.toString(),
title: `content${i + 1}`,
description: `description of content${i + 1}`,
chosen: Math.random() * 2 > 1,
};
if (data.chosen) {
targetKeys.push(data.key);
}
mockData.push(data);
}
this.mockData = mockData;
this.targetKeys = targetKeys;
},
renderItem(item) {
const customLabel = (
<span class="custom-item">
{item.title} - {item.description}
</span>
);
return {
label: customLabel, // for displayed item
value: item.title, // for title and filter matching
};
},
handleChange(targetKeys, direction, moveKeys) {
console.log(targetKeys, direction, moveKeys);
this.targetKeys = targetKeys;
},
},
};
2018-04-06 16:20:45 +00:00
</script>
```