119 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Vue
		
	
	
| <docs>
 | |
| ---
 | |
| order: 14
 | |
| title:
 | |
|   zh-CN: 定制回填内容
 | |
|   en-US: Custom selection render
 | |
| ---
 | |
| 
 | |
| ## zh-CN
 | |
| 
 | |
| 使用 `optionLabelProp` 指定回填到选择框的 `Option` 属性。
 | |
| 
 | |
| 或者使用 `tagRender` 插槽自定义渲染节点
 | |
| 
 | |
| ## en-US
 | |
| 
 | |
| Spacified the prop name of Option which will be rendered in select box.
 | |
| 
 | |
| or use `tagRender` slot for custom rendering of tags.
 | |
| </docs>
 | |
| 
 | |
| <template>
 | |
|   <a-space direction="vertical" style="width: 100%">
 | |
|     <a-select
 | |
|       v-model:value="value"
 | |
|       mode="multiple"
 | |
|       style="width: 100%"
 | |
|       placeholder="select one country"
 | |
|       option-label-prop="children"
 | |
|     >
 | |
|       <a-select-option value="china" label="China">
 | |
|         <span role="img" aria-label="China">🇨🇳</span>
 | |
|           China (中国)
 | |
|       </a-select-option>
 | |
|       <a-select-option value="usa" label="USA">
 | |
|         <span role="img" aria-label="USA">🇺🇸</span>
 | |
|           USA (美国)
 | |
|       </a-select-option>
 | |
|       <a-select-option value="japan" label="Japan">
 | |
|         <span role="img" aria-label="Japan">🇯🇵</span>
 | |
|           Japan (日本)
 | |
|       </a-select-option>
 | |
|       <a-select-option value="korea" label="Korea">
 | |
|         <span role="img" aria-label="Korea">🇰🇷</span>
 | |
|           Korea (韩国)
 | |
|       </a-select-option>
 | |
|     </a-select>
 | |
| 
 | |
|     <a-select
 | |
|       v-model:value="value"
 | |
|       mode="multiple"
 | |
|       style="width: 100%"
 | |
|       placeholder="select one country"
 | |
|       option-label-prop="label"
 | |
|       :options="options"
 | |
|     >
 | |
|       <template #option="{ value: val, label, icon }">
 | |
|         <span role="img" :aria-label="val">{{ icon }}</span>
 | |
|           {{ label }}
 | |
|       </template>
 | |
|     </a-select>
 | |
|     <span>Note: v-slot:option support from v2.2.5</span>
 | |
|   </a-space>
 | |
|   <br />
 | |
|   <br />
 | |
|   <a-space direction="vertical" style="width: 100%">
 | |
|     <a-select
 | |
|       v-model:value="value"
 | |
|       mode="multiple"
 | |
|       style="width: 100%"
 | |
|       placeholder="select one country"
 | |
|       :options="options"
 | |
|     >
 | |
|       <template #option="{ value: val, label, icon }">
 | |
|         <span role="img" :aria-label="val">{{ icon }}</span>
 | |
|           {{ label }}
 | |
|       </template>
 | |
|       <template #tagRender="{ value: val, label, closable, onClose, option }">
 | |
|         <a-tag :closable="closable" style="margin-right: 3px" @close="onClose">
 | |
|           {{ label }}  
 | |
|           <span role="img" :aria-label="val">{{ option.icon }}</span>
 | |
|         </a-tag>
 | |
|       </template>
 | |
|     </a-select>
 | |
|     <span>Note: v-slot:tagRender support from v3.0</span>
 | |
|   </a-space>
 | |
| </template>
 | |
| <script lang="ts" setup>
 | |
| import { ref, watch } from 'vue';
 | |
| 
 | |
| const value = ref(['china']);
 | |
| 
 | |
| const options = ref([
 | |
|   {
 | |
|     value: 'china',
 | |
|     label: 'China (中国)',
 | |
|     icon: '🇨🇳',
 | |
|   },
 | |
|   {
 | |
|     value: 'usa',
 | |
|     label: 'USA (美国)',
 | |
|     icon: '🇺🇸',
 | |
|   },
 | |
|   {
 | |
|     value: 'japan',
 | |
|     label: 'Japan (日本)',
 | |
|     icon: '🇯🇵',
 | |
|   },
 | |
|   {
 | |
|     value: 'korea',
 | |
|     label: 'Korea (韩国)',
 | |
|     icon: '🇨🇰',
 | |
|   },
 | |
| ]);
 | |
| watch(value, val => {
 | |
|   console.log(`selected:`, val);
 | |
| });
 | |
| </script>
 |