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.
		
		
		
		
			
				
					29 lines
				
				644 B
			
		
		
			
		
	
	
					29 lines
				
				644 B
			| 
								 
											2 years ago
										 
									 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * 监听 dom size 变化
							 | 
						||
| 
								 | 
							
								 * @param {*} target HTMLElement
							 | 
						||
| 
								 | 
							
								 * @param {*} callback 参数 rect
							 | 
						||
| 
								 | 
							
								 * @param {*} times n次后注销
							 | 
						||
| 
								 | 
							
								 * @returns 销毁函数
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								export function onceObserver(target, callback, times = 2) {
							 | 
						||
| 
								 | 
							
								  let index = 1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  const resizeObserve = new ResizeObserver(function ([{ target }]) {
							 | 
						||
| 
								 | 
							
								    callback?.(target.getBoundingClientRect());
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (index++ > times - 1) this.disconnect();
							 | 
						||
| 
								 | 
							
								  });
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  resizeObserve.observe(target);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  function destroyObserver() {
							 | 
						||
| 
								 | 
							
								    resizeObserve.disconnect();
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  if (typeof this.$once === "function") {
							 | 
						||
| 
								 | 
							
								    this.$once("hook:beforeDestroy", destroyObserver);
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  return destroyObserver;
							 | 
						||
| 
								 | 
							
								}
							 |