refactor(reactivity): improve tree-shaking annotations
This commit is contained in:
		
							parent
							
								
									601a290caa
								
							
						
					
					
						commit
						f8a6b57ddd
					
				| @ -42,12 +42,15 @@ const shallowGet = /*#__PURE__*/ createGetter(false, true) | ||||
| const readonlyGet = /*#__PURE__*/ createGetter(true) | ||||
| const shallowReadonlyGet = /*#__PURE__*/ createGetter(true, true) | ||||
| 
 | ||||
| const arrayInstrumentations: Record<string, Function> = {} | ||||
| // instrument identity-sensitive Array methods to account for possible reactive
 | ||||
| // values
 | ||||
| ;(['includes', 'indexOf', 'lastIndexOf'] as const).forEach(key => { | ||||
| const arrayInstrumentations = /*#__PURE__*/ createArrayInstrumentations() | ||||
| 
 | ||||
| function createArrayInstrumentations() { | ||||
|   const instrumentations: Record<string, Function> = {} | ||||
|   // instrument identity-sensitive Array methods to account for possible reactive
 | ||||
|   // values
 | ||||
|   ;(['includes', 'indexOf', 'lastIndexOf'] as const).forEach(key => { | ||||
|     const method = Array.prototype[key] as any | ||||
|   arrayInstrumentations[key] = function(this: unknown[], ...args: unknown[]) { | ||||
|     instrumentations[key] = function(this: unknown[], ...args: unknown[]) { | ||||
|       const arr = toRaw(this) | ||||
|       for (let i = 0, l = this.length; i < l; i++) { | ||||
|         track(arr, TrackOpTypes.GET, i + '') | ||||
| @ -61,18 +64,20 @@ const arrayInstrumentations: Record<string, Function> = {} | ||||
|         return res | ||||
|       } | ||||
|     } | ||||
| }) | ||||
| // instrument length-altering mutation methods to avoid length being tracked
 | ||||
| // which leads to infinite loops in some cases (#2137)
 | ||||
| ;(['push', 'pop', 'shift', 'unshift', 'splice'] as const).forEach(key => { | ||||
|   }) | ||||
|   // instrument length-altering mutation methods to avoid length being tracked
 | ||||
|   // which leads to infinite loops in some cases (#2137)
 | ||||
|   ;(['push', 'pop', 'shift', 'unshift', 'splice'] as const).forEach(key => { | ||||
|     const method = Array.prototype[key] as any | ||||
|   arrayInstrumentations[key] = function(this: unknown[], ...args: unknown[]) { | ||||
|     instrumentations[key] = function(this: unknown[], ...args: unknown[]) { | ||||
|       pauseTracking() | ||||
|       const res = method.apply(this, args) | ||||
|       resetTracking() | ||||
|       return res | ||||
|     } | ||||
| }) | ||||
|   }) | ||||
|   return instrumentations | ||||
| } | ||||
| 
 | ||||
| function createGetter(isReadonly = false, shallow = false) { | ||||
|   return function get(target: Target, key: string | symbol, receiver: object) { | ||||
| @ -224,7 +229,7 @@ export const readonlyHandlers: ProxyHandler<object> = { | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| export const shallowReactiveHandlers: ProxyHandler<object> = extend( | ||||
| export const shallowReactiveHandlers = /*#__PURE__*/ extend( | ||||
|   {}, | ||||
|   mutableHandlers, | ||||
|   { | ||||
| @ -236,7 +241,7 @@ export const shallowReactiveHandlers: ProxyHandler<object> = extend( | ||||
| // Props handlers are special in the sense that it should not unwrap top-level
 | ||||
| // refs (in order to allow refs to be explicitly passed down), but should
 | ||||
| // retain the reactivity of the normal readonly object.
 | ||||
| export const shallowReadonlyHandlers: ProxyHandler<object> = extend( | ||||
| export const shallowReadonlyHandlers = /*#__PURE__*/ extend( | ||||
|   {}, | ||||
|   readonlyHandlers, | ||||
|   { | ||||
|  | ||||
| @ -236,7 +236,8 @@ function createReadonlyMethod(type: TriggerOpTypes): Function { | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| const mutableInstrumentations: Record<string, Function> = { | ||||
| function createInstrumentations() { | ||||
|   const mutableInstrumentations: Record<string, Function> = { | ||||
|     get(this: MapTypes, key: unknown) { | ||||
|       return get(this, key) | ||||
|     }, | ||||
| @ -249,9 +250,9 @@ const mutableInstrumentations: Record<string, Function> = { | ||||
|     delete: deleteEntry, | ||||
|     clear, | ||||
|     forEach: createForEach(false, false) | ||||
| } | ||||
|   } | ||||
| 
 | ||||
| const shallowInstrumentations: Record<string, Function> = { | ||||
|   const shallowInstrumentations: Record<string, Function> = { | ||||
|     get(this: MapTypes, key: unknown) { | ||||
|       return get(this, key, false, true) | ||||
|     }, | ||||
| @ -264,9 +265,9 @@ const shallowInstrumentations: Record<string, Function> = { | ||||
|     delete: deleteEntry, | ||||
|     clear, | ||||
|     forEach: createForEach(false, true) | ||||
| } | ||||
|   } | ||||
| 
 | ||||
| const readonlyInstrumentations: Record<string, Function> = { | ||||
|   const readonlyInstrumentations: Record<string, Function> = { | ||||
|     get(this: MapTypes, key: unknown) { | ||||
|       return get(this, key, true) | ||||
|     }, | ||||
| @ -281,9 +282,9 @@ const readonlyInstrumentations: Record<string, Function> = { | ||||
|     delete: createReadonlyMethod(TriggerOpTypes.DELETE), | ||||
|     clear: createReadonlyMethod(TriggerOpTypes.CLEAR), | ||||
|     forEach: createForEach(true, false) | ||||
| } | ||||
|   } | ||||
| 
 | ||||
| const shallowReadonlyInstrumentations: Record<string, Function> = { | ||||
|   const shallowReadonlyInstrumentations: Record<string, Function> = { | ||||
|     get(this: MapTypes, key: unknown) { | ||||
|       return get(this, key, true, true) | ||||
|     }, | ||||
| @ -298,10 +299,10 @@ const shallowReadonlyInstrumentations: Record<string, Function> = { | ||||
|     delete: createReadonlyMethod(TriggerOpTypes.DELETE), | ||||
|     clear: createReadonlyMethod(TriggerOpTypes.CLEAR), | ||||
|     forEach: createForEach(true, true) | ||||
| } | ||||
|   } | ||||
| 
 | ||||
| const iteratorMethods = ['keys', 'values', 'entries', Symbol.iterator] | ||||
| iteratorMethods.forEach(method => { | ||||
|   const iteratorMethods = ['keys', 'values', 'entries', Symbol.iterator] | ||||
|   iteratorMethods.forEach(method => { | ||||
|     mutableInstrumentations[method as string] = createIterableMethod( | ||||
|       method, | ||||
|       false, | ||||
| @ -322,7 +323,22 @@ iteratorMethods.forEach(method => { | ||||
|       true, | ||||
|       true | ||||
|     ) | ||||
| }) | ||||
|   }) | ||||
| 
 | ||||
|   return [ | ||||
|     mutableInstrumentations, | ||||
|     readonlyInstrumentations, | ||||
|     shallowInstrumentations, | ||||
|     shallowReadonlyInstrumentations | ||||
|   ] | ||||
| } | ||||
| 
 | ||||
| const [ | ||||
|   mutableInstrumentations, | ||||
|   readonlyInstrumentations, | ||||
|   shallowInstrumentations, | ||||
|   shallowReadonlyInstrumentations | ||||
| ] = /* #__PURE__*/ createInstrumentations() | ||||
| 
 | ||||
| function createInstrumentationGetter(isReadonly: boolean, shallow: boolean) { | ||||
|   const instrumentations = shallow | ||||
| @ -357,21 +373,21 @@ function createInstrumentationGetter(isReadonly: boolean, shallow: boolean) { | ||||
| } | ||||
| 
 | ||||
| export const mutableCollectionHandlers: ProxyHandler<CollectionTypes> = { | ||||
|   get: createInstrumentationGetter(false, false) | ||||
|   get: /*#__PURE__*/ createInstrumentationGetter(false, false) | ||||
| } | ||||
| 
 | ||||
| export const shallowCollectionHandlers: ProxyHandler<CollectionTypes> = { | ||||
|   get: createInstrumentationGetter(false, true) | ||||
|   get: /*#__PURE__*/ createInstrumentationGetter(false, true) | ||||
| } | ||||
| 
 | ||||
| export const readonlyCollectionHandlers: ProxyHandler<CollectionTypes> = { | ||||
|   get: createInstrumentationGetter(true, false) | ||||
|   get: /*#__PURE__*/ createInstrumentationGetter(true, false) | ||||
| } | ||||
| 
 | ||||
| export const shallowReadonlyCollectionHandlers: ProxyHandler< | ||||
|   CollectionTypes | ||||
| > = { | ||||
|   get: createInstrumentationGetter(true, true) | ||||
|   get: /*#__PURE__*/ createInstrumentationGetter(true, true) | ||||
| } | ||||
| 
 | ||||
| function checkIdentityKeys( | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user