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>
|
|
|
|
|
```
|