68 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Markdown
		
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Markdown
		
	
	
| <cn>
 | |
| #### 带搜索框
 | |
| 带搜索框的穿梭框,可以自定义搜索函数。
 | |
| </cn>
 | |
| 
 | |
| <us>
 | |
| #### Search
 | |
| Transfer with a search box.
 | |
| </us>
 | |
| 
 | |
| ```tpl
 | |
| <template>
 | |
|   <a-transfer
 | |
|     :dataSource="mockData"
 | |
|     showSearch
 | |
|     :filterOption="filterOption"
 | |
|     :targetKeys="targetKeys"
 | |
|     @change="handleChange"
 | |
|     @search="handleSearch"
 | |
|     :render="item=>item.title"
 | |
|   >
 | |
|   </a-transfer>
 | |
| </template>
 | |
| <script>
 | |
|   export default {
 | |
|     data() {
 | |
|       return {
 | |
|         mockData: [],
 | |
|         targetKeys: [],
 | |
|       };
 | |
|     },
 | |
|     mounted() {
 | |
|       this.getMock();
 | |
|     },
 | |
|     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;
 | |
|       },
 | |
|       filterOption(inputValue, option) {
 | |
|         return option.description.indexOf(inputValue) > -1;
 | |
|       },
 | |
|       handleChange(targetKeys, direction, moveKeys) {
 | |
|         console.log(targetKeys, direction, moveKeys);
 | |
|         this.targetKeys = targetKeys;
 | |
|       },
 | |
|       handleSearch(dir, value) {
 | |
|         console.log('search:', dir, value);
 | |
|       },
 | |
|     },
 | |
|   };
 | |
| </script>
 | |
| ```
 |