mirror of
				https://gitee.com/vant-contrib/vant-weapp.git
				synced 2025-10-26 09:22:09 +08:00 
			
		
		
		
	
							parent
							
								
									cdc27120a5
								
							
						
					
					
						commit
						d99829d28d
					
				| @ -9,7 +9,10 @@ VantComponent({ | |||||||
| 
 | 
 | ||||||
|   relation: { |   relation: { | ||||||
|     name: 'tabbar', |     name: 'tabbar', | ||||||
|     type: 'ancestor' |     type: 'ancestor', | ||||||
|  |     linked(target: Weapp.Component) { | ||||||
|  |       this.parent = target; | ||||||
|  |     } | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   data: { |   data: { | ||||||
| @ -18,17 +21,17 @@ VantComponent({ | |||||||
| 
 | 
 | ||||||
|   methods: { |   methods: { | ||||||
|     onClick() { |     onClick() { | ||||||
|       const parent = this.getRelationNodes('../tabbar/index')[0]; |       if (this.parent) { | ||||||
|       if (parent) { |         this.parent.onChange(this); | ||||||
|         parent.onChange(this); |  | ||||||
|       } |       } | ||||||
|       this.$emit('click'); |       this.$emit('click'); | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     setActive({ active, color }) { |     setActive({ active, color }): Promise<void> { | ||||||
|       if (this.data.active !== active) { |       if (this.data.active !== active) { | ||||||
|         this.set({ active, color }); |         return this.set({ active, color }); | ||||||
|       } |       } | ||||||
|  |       return Promise.resolve(); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| }); | }); | ||||||
|  | |||||||
| @ -1,9 +1,11 @@ | |||||||
|  | <wxs src="../wxs/utils.wxs" module="utils" /> | ||||||
|  | 
 | ||||||
| <view | <view | ||||||
|   class="van-tabbar-item custom-class {{ active ? 'van-tabbar-item--active' : '' }}" |   class="{{ utils.bem('tabbar-item', { active }) }} custom-class" | ||||||
|   style="{{ active && color ? 'color: ' + color : '' }}" |   style="{{ active && color ? 'color: ' + color : '' }}" | ||||||
|   bind:tap="onClick" |   bind:tap="onClick" | ||||||
| > | > | ||||||
|   <view class="van-tabbar-item__icon {{ dot ? 'van-tabbar-item__icon--dot' : '' }}"> |   <view class="{{ utils.bem('tabbar-item__icon', { dot }) }}"> | ||||||
|     <van-icon |     <van-icon | ||||||
|       wx:if="{{ icon }}" |       wx:if="{{ icon }}" | ||||||
|       name="{{ icon }}" |       name="{{ icon }}" | ||||||
|  | |||||||
| @ -131,10 +131,3 @@ Page({ | |||||||
| |-----------|-----------| | |-----------|-----------| | ||||||
| | icon | 未选中时的图标 | | | icon | 未选中时的图标 | | ||||||
| | icon-active | 选中时的图标 | | | icon-active | 选中时的图标 | | ||||||
| 
 |  | ||||||
| ### 更新日志 |  | ||||||
| 
 |  | ||||||
| | 版本 | 类型 | 内容 | |  | ||||||
| |-----------|-----------|-----------| |  | ||||||
| | 0.1.1 | feature | 新增组件 | |  | ||||||
| | 0.2.1 | bugfix | 修复 z-index 不生效的问题 | |  | ||||||
|  | |||||||
| @ -8,16 +8,14 @@ VantComponent({ | |||||||
|     name: 'tabbar-item', |     name: 'tabbar-item', | ||||||
|     type: 'descendant', |     type: 'descendant', | ||||||
|     linked(target: Weapp.Component) { |     linked(target: Weapp.Component) { | ||||||
|       this.data.items.push(target); |       this.children = this.children || []; | ||||||
|       setTimeout(() => { |       this.children.push(target); | ||||||
|       this.setActiveItem(); |       this.setActiveItem(); | ||||||
|       }); |  | ||||||
|     }, |     }, | ||||||
|     unlinked(target: Weapp.Component) { |     unlinked(target: Weapp.Component) { | ||||||
|       this.data.items = this.data.items.filter(item => item !== target); |       this.children = this.children || []; | ||||||
|       setTimeout(() => { |       this.children = this.children.filter(item => item !== target); | ||||||
|       this.setActiveItem(); |       this.setActiveItem(); | ||||||
|       }); |  | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
| @ -34,12 +32,8 @@ VantComponent({ | |||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   data: { |  | ||||||
|     items: [] |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   watch: { |   watch: { | ||||||
|     active(active) { |     active(active: number) { | ||||||
|       this.currentActive = active; |       this.currentActive = active; | ||||||
|       this.setActiveItem(); |       this.setActiveItem(); | ||||||
|     } |     } | ||||||
| @ -50,21 +44,28 @@ VantComponent({ | |||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   methods: { |   methods: { | ||||||
|     setActiveItem() { |     setActiveItem(): Promise<any> { | ||||||
|       this.data.items.forEach((item, index) => { |       if (!Array.isArray(this.children) || !this.children.length) { | ||||||
|  |         return Promise.resolve(); | ||||||
|  |       } | ||||||
|  |       return Promise.all( | ||||||
|  |         this.children.map((item: Weapp.Component, index: number) => | ||||||
|           item.setActive({ |           item.setActive({ | ||||||
|             active: index === this.currentActive, |             active: index === this.currentActive, | ||||||
|             color: this.data.activeColor |             color: this.data.activeColor | ||||||
|         }); |           }) | ||||||
|       }); |         ) | ||||||
|  |       ); | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     onChange(child) { |     onChange(child: Weapp.Component) { | ||||||
|       const active = this.data.items.indexOf(child); |       const active = (this.children || []).indexOf(child); | ||||||
|  | 
 | ||||||
|       if (active !== this.currentActive && active !== -1) { |       if (active !== this.currentActive && active !== -1) { | ||||||
|         this.$emit('change', active); |  | ||||||
|         this.currentActive = active; |         this.currentActive = active; | ||||||
|         this.setActiveItem(); |         this.setActiveItem().then(() => { | ||||||
|  |           this.$emit('change', active); | ||||||
|  |         }); | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user