mirror of
				https://github.com/youzan/vant.git
				synced 2025-10-20 18:54:24 +00:00 
			
		
		
		
	Add deep-select component and fix a popup bug. (#103)
* feat: new deep select * fix: add deep-select test * fix: import * fix: icon import
This commit is contained in:
		
							
								
								
									
										85
									
								
								packages/deep-select/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										85
									
								
								packages/deep-select/index.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,85 @@ | ||||
| <template> | ||||
|   <div class="van-deep-select" v-bind:style="{ height: mainHeight + 'px' }"> | ||||
|     <div class="van-deep-select__nav"> | ||||
|       <div | ||||
|         v-for="(item, index) in items" | ||||
|         class="van-deep-select__nitem" | ||||
|         v-bind:class="{ 'van-deep-select__nitem--active': mainActiveIndex === index }" | ||||
|         @click="onNavClick(index)"> | ||||
|         {{ item.text }} | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="van-deep-select__content" v-bind:style="{ height: itemHeight + 'px' }"> | ||||
|       <div | ||||
|         v-for="item in subItems" | ||||
|         :key="item.id" | ||||
|         class="van-deep-select__item" | ||||
|         v-bind:class="{ 'van-deep-select__item--active': activeId === item.id }" | ||||
|         @click="onItemSelect(item)"> | ||||
|         {{ item.text }} | ||||
|         <van-icon | ||||
|           v-if="activeId === item.id" | ||||
|           name="success" | ||||
|           class="van-deep-select__selected" | ||||
|         ></van-icon> | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import Icon from 'packages/icon'; | ||||
|  | ||||
| export default { | ||||
|   name: 'van-deep-select', | ||||
|  | ||||
|   components: { | ||||
|     'van-icon': Icon | ||||
|   }, | ||||
|  | ||||
|   props: { | ||||
|     items: { | ||||
|       type: Array, | ||||
|       default () { | ||||
|         return []; | ||||
|       } | ||||
|     }, | ||||
|     mainActiveIndex: { | ||||
|       type: Number, | ||||
|       default: 0 | ||||
|     }, | ||||
|     activeId: { | ||||
|       type: Number, | ||||
|       default: 0 | ||||
|     }, | ||||
|     maxHeight: { | ||||
|       type: Number, | ||||
|       default: 300 | ||||
|     } | ||||
|   }, | ||||
|  | ||||
|   computed: { | ||||
|     subItems() { | ||||
|       const selectedItem = this.items[this.mainActiveIndex] || {}; | ||||
|       return selectedItem.children || []; | ||||
|     }, | ||||
|     mainHeight() { | ||||
|       const maxHeight = Math.max(this.items.length * 44, this.subItems.length * 44); | ||||
|       return Math.min(maxHeight, this.maxHeight); | ||||
|     }, | ||||
|     itemHeight() { | ||||
|       return Math.min(this.subItems.length * 44, this.maxHeight); | ||||
|     } | ||||
|   }, | ||||
|  | ||||
|   methods: { | ||||
|     onNavClick(index) { | ||||
|       this.$emit('navclick', index); | ||||
|     }, | ||||
|     onItemSelect(data) { | ||||
|       const exportData = Object.assign({}, data); | ||||
|       this.$emit('itemclick', exportData); | ||||
|     } | ||||
|   } | ||||
| }; | ||||
| </script> | ||||
		Reference in New Issue
	
	Block a user
	 WyTiny
					WyTiny