73 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Vue
		
	
	
| <docs>
 | |
| ---
 | |
| order: 13
 | |
| title:
 | |
|   zh-CN: ๆฉๅฑ่ๅ
 | |
|   en-US: Custom dropdown
 | |
| ---
 | |
| 
 | |
| ## zh-CN
 | |
| 
 | |
| ไฝฟ็จ `dropdownRender` ๅฏนไธๆ่ๅ่ฟ่ก่ช็ฑๆฉๅฑใ
 | |
| 
 | |
| ## en-US
 | |
| 
 | |
| Customize the dropdown menu via `dropdownRender`.
 | |
| 
 | |
| </docs>
 | |
| 
 | |
| <template>
 | |
|   <a-select
 | |
|     v-model:value="value"
 | |
|     placeholder="custom dropdown render"
 | |
|     style="width: 300px"
 | |
|     :options="items.map(item => ({ value: item }))"
 | |
|   >
 | |
|     <template #dropdownRender="{ menuNode: menu }">
 | |
|       <v-nodes :vnodes="menu" />
 | |
|       <a-divider style="margin: 4px 0" />
 | |
|       <a-space style="padding: 4px 8px">
 | |
|         <a-input ref="inputRef" v-model:value="name" placeholder="Please enter item" />
 | |
|         <a-button type="text" @click="addItem">
 | |
|           <template #icon>
 | |
|             <plus-outlined />
 | |
|           </template>
 | |
|           Add item
 | |
|         </a-button>
 | |
|       </a-space>
 | |
|     </template>
 | |
|   </a-select>
 | |
| </template>
 | |
| <script lang="ts" setup>
 | |
| import { PlusOutlined } from '@ant-design/icons-vue';
 | |
| import { defineComponent, ref } from 'vue';
 | |
| 
 | |
| const VNodes = defineComponent({
 | |
|   props: {
 | |
|     vnodes: {
 | |
|       type: Object,
 | |
|       required: true,
 | |
|     },
 | |
|   },
 | |
|   render() {
 | |
|     return this.vnodes;
 | |
|   },
 | |
| });
 | |
| 
 | |
| let index = 0;
 | |
| const items = ref(['jack', 'lucy']);
 | |
| const value = ref();
 | |
| const inputRef = ref();
 | |
| const name = ref();
 | |
| 
 | |
| const addItem = e => {
 | |
|   e.preventDefault();
 | |
|   console.log('addItem');
 | |
|   items.value.push(name.value || `New item ${(index += 1)}`);
 | |
|   name.value = '';
 | |
|   setTimeout(() => {
 | |
|     inputRef.value?.focus();
 | |
|   }, 0);
 | |
| };
 | |
| </script>
 |