You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							39 lines
						
					
					
						
							1.1 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							39 lines
						
					
					
						
							1.1 KiB
						
					
					
				| import { getRect } from '../common/utils'; | |
| function useAnimation(context, expanded, mounted, height) { | |
|     const animation = wx.createAnimation({ | |
|         duration: 0, | |
|         timingFunction: 'ease-in-out', | |
|     }); | |
|     if (expanded) { | |
|         if (height === 0) { | |
|             animation.height('auto').top(1).step(); | |
|         } | |
|         else { | |
|             animation | |
|                 .height(height) | |
|                 .top(1) | |
|                 .step({ | |
|                 duration: mounted ? 300 : 1, | |
|             }) | |
|                 .height('auto') | |
|                 .step(); | |
|         } | |
|         context.setData({ | |
|             animation: animation.export(), | |
|         }); | |
|         return; | |
|     } | |
|     animation.height(height).top(0).step({ duration: 1 }).height(0).step({ | |
|         duration: 300, | |
|     }); | |
|     context.setData({ | |
|         animation: animation.export(), | |
|     }); | |
| } | |
| export function setContentAnimate(context, expanded, mounted) { | |
|     getRect(context, '.van-collapse-item__content') | |
|         .then((rect) => rect.height) | |
|         .then((height) => { | |
|         useAnimation(context, expanded, mounted, height); | |
|     }); | |
| }
 | |
| 
 |