- ngrx devtools 使用時(shí)飞苇,當(dāng)配置了需要編譯檢查錯(cuò)誤如:
import { NgModule } from '@angular/core';
import { StoreModule } from '@ngrx/store';
import { StoreDevtoolsModule } from '@ngrx/store-devtools';
import { environment } from '../../environments/environment';
import { agentReducer } from './reducers/agent.reducer';
@NgModule({
declarations: [],
imports: [
StoreModule.forRoot({ agent: agentReducer }, {
// runtimeChecks: {
// strictStateImmutability: true,
// strictActionImmutability: true,
// strictStateSerializability: true,
// strictActionSerializability: true,
// }
}),
StoreDevtoolsModule.instrument({
maxAge: 20,
logOnly: environment.production
})
]
})
export class AppStoreModule { }
就算在外層邏輯中修改了store里的相同名字的變量,也會(huì)報(bào)錯(cuò)蜗顽,錯(cuò)誤信息如:
core.js:6014 ERROR TypeError: Cannot assign to read only property '1' of object '[object Array]' at Array.splice (<anonymous>)
關(guān)閉編譯檢查就能work了 = =
- ngrx reducer的處理邏輯
- ”散布運(yùn)算符僅執(zhí)行淺復(fù)制,而不處理深層嵌套的對(duì)象雨让。您需要復(fù)制對(duì)象中的每個(gè)級(jí)別以確保不變性雇盖。“
constructor & ngOnit的區(qū)別
- 無(wú)論您是否在TypeScript類(lèi)中實(shí)現(xiàn)它栖忠,在創(chuàng)建類(lèi)的實(shí)例時(shí)仍會(huì)調(diào)用它崔挖。這是因?yàn)閷ypescript類(lèi)構(gòu)造函數(shù)轉(zhuǎn)換為JavaScript構(gòu)造函數(shù):
- constructor 會(huì)被強(qiáng)制調(diào)用 而ngOnit只會(huì)在實(shí)現(xiàn)方法的時(shí)候被調(diào)用
- @Input通信機(jī)制是作為后續(xù)更改檢測(cè)階段的一部分進(jìn)行處理的,因此輸入綁定在構(gòu)造函數(shù)中不可用庵寞。 當(dāng)Angular開(kāi)始更改檢測(cè)時(shí)狸相,將構(gòu)建組件樹(shù),并已調(diào)用樹(shù)中所有組件的構(gòu)造函數(shù)捐川。同樣在這一點(diǎn)上脓鹃,每個(gè)組件的模板節(jié)點(diǎn)都添加到DOM中。在這里古沥,您可以獲得初始化組件可能需要的所有數(shù)據(jù)-DI提供程序瘸右,DOM和輸入綁定。
- 當(dāng)Angular調(diào)用ngOnInit時(shí)岩齿,它已經(jīng)完成了組件DOM的創(chuàng)建太颤,并通過(guò)構(gòu)造函數(shù)和已處理的輸入綁定注入了所有必需的依賴(lài)項(xiàng)。因此盹沈,這里您具有所有必需的信息龄章,這使它成為執(zhí)行初始化邏輯的好地方
- It’s a common practice to use
ngOnInit
to perform initialization logic even if this logic doesn’t depend on DI, DOM or input bindings.
后端代理的跨域問(wèn)題