mirror of
				https://gitee.com/vant-contrib/vant.git
				synced 2025-10-26 01:02:12 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			58 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { trigger } from './event';
 | |
| 
 | |
| function mockHTMLElementOffset() {
 | |
|   Object.defineProperties(HTMLElement.prototype, {
 | |
|     offsetParent: {
 | |
|       get() {
 | |
|         return this.parentNode || {};
 | |
|       },
 | |
|     },
 | |
|     offsetLeft: {
 | |
|       get() {
 | |
|         return parseFloat(window.getComputedStyle(this).marginLeft) || 0;
 | |
|       },
 | |
|     },
 | |
|     offsetTop: {
 | |
|       get() {
 | |
|         return parseFloat(window.getComputedStyle(this).marginTop) || 0;
 | |
|       },
 | |
|     },
 | |
|     offsetHeight: {
 | |
|       get() {
 | |
|         return parseFloat(window.getComputedStyle(this).height) || 0;
 | |
|       },
 | |
|     },
 | |
|     offsetWidth: {
 | |
|       get() {
 | |
|         return parseFloat(window.getComputedStyle(this).width) || 0;
 | |
|       },
 | |
|     },
 | |
|   });
 | |
| }
 | |
| 
 | |
| export function mockScrollIntoView() {
 | |
|   const fn = jest.fn();
 | |
|   Element.prototype.scrollIntoView = fn;
 | |
|   return fn;
 | |
| }
 | |
| 
 | |
| export function mockGetBoundingClientRect(
 | |
|   rect: ClientRect | DOMRect
 | |
| ): Function {
 | |
|   const originMethod = Element.prototype.getBoundingClientRect;
 | |
| 
 | |
|   Element.prototype.getBoundingClientRect = <any>jest.fn(() => rect);
 | |
| 
 | |
|   return function () {
 | |
|     Element.prototype.getBoundingClientRect = originMethod;
 | |
|   };
 | |
| }
 | |
| 
 | |
| export function mockScrollTop(value: number) {
 | |
|   Object.defineProperty(window, 'scrollTop', { value, writable: true });
 | |
|   trigger(window, 'scroll');
 | |
| }
 | |
| 
 | |
| mockScrollIntoView();
 | |
| mockHTMLElementOffset();
 |