refactor(core): rename ngInjectorDef to ɵinj (#33151)
Injector defs are not considered public API, so the property that contains them should be prefixed with Angular's marker for "private" ('ɵ') to discourage apps from relying on def APIs directly. This commit adds the prefix and shortens the name from ngInjectorDef to inj. This is because property names cannot be minified by Uglify without turning on property mangling (which most apps have turned off) and are thus size-sensitive. PR Close #33151
This commit is contained in:

committed by
Matias Niemelä

parent
3e14c2d02c
commit
cda9248b33
@ -8,7 +8,7 @@
|
||||
|
||||
import {R3InjectorMetadataFacade, getCompilerFacade} from '../../compiler/compiler_facade';
|
||||
import {resolveForwardRef} from '../../di/forward_ref';
|
||||
import {NG_INJECTOR_DEF} from '../../di/interface/defs';
|
||||
import {NG_INJ_DEF} from '../../di/interface/defs';
|
||||
import {reflectDependencies} from '../../di/jit/util';
|
||||
import {Type} from '../../interface/type';
|
||||
import {Component} from '../../metadata';
|
||||
@ -93,7 +93,7 @@ export function compileNgModule(moduleType: Type<any>, ngModule: NgModule = {}):
|
||||
}
|
||||
|
||||
/**
|
||||
* Compiles and adds the `ɵmod` and `ngInjectorDef` properties to the module class.
|
||||
* Compiles and adds the `ɵmod` and `ɵinj` properties to the module class.
|
||||
*
|
||||
* It's possible to compile a module via this API which will allow duplicate declarations in its
|
||||
* root.
|
||||
@ -135,7 +135,7 @@ export function compileNgModuleDefs(
|
||||
});
|
||||
|
||||
let ngInjectorDef: any = null;
|
||||
Object.defineProperty(moduleType, NG_INJECTOR_DEF, {
|
||||
Object.defineProperty(moduleType, NG_INJ_DEF, {
|
||||
get: () => {
|
||||
if (ngInjectorDef === null) {
|
||||
ngDevMode && verifySemanticsOfNgModuleDef(
|
||||
@ -151,7 +151,7 @@ export function compileNgModuleDefs(
|
||||
],
|
||||
};
|
||||
ngInjectorDef = getCompilerFacade().compileInjector(
|
||||
angularCoreEnv, `ng:///${moduleType.name}/ngInjectorDef.js`, meta);
|
||||
angularCoreEnv, `ng:///${moduleType.name}/ɵinj.js`, meta);
|
||||
}
|
||||
return ngInjectorDef;
|
||||
},
|
||||
|
Reference in New Issue
Block a user