如果private在組件類上聲明了變量,我是否應(yīng)該能夠在該組件的模板中訪問它?@Component({ selector: 'my-app', template: ` <div> <h2>{{title}}</h2> <h2>Hello {{userName}}</h2> // I am getting this name </div> `,})export class App { public title = 'Angular 2'; private userName = "Test Name"; //declared as private}
3 回答

守著一只汪
TA貢獻(xiàn)1872條經(jīng)驗(yàn) 獲得超4個(gè)贊
不,您不應(yīng)該在模板中使用私有變量。
雖然我喜歡drewmoore的答案,并且看到了完美的概念邏輯,但在實(shí)現(xiàn)上卻是錯(cuò)誤的。模板不存在于組件類中,而是在它們之外。查看此回購作為證明。
它起作用的唯一原因是因?yàn)門ypeScript的private關(guān)鍵字并未真正使成員私有。即時(shí)編譯在運(yùn)行時(shí)在瀏覽器中進(jìn)行,并且JS沒有任何私有成員的概念(還可以嗎?)。幸得桑德埃利亞斯為把我在正確的軌道上。
使用ngc和提前編譯,如果嘗試從模板訪問組件的私有成員,則會出現(xiàn)錯(cuò)誤??寺⊙菔緜}庫,將MyComponent成員的可見性更改為private,運(yùn)行時(shí)將出現(xiàn)編譯錯(cuò)誤ngc。這也是提前編譯的特定答案。
- 3 回答
- 0 關(guān)注
- 1306 瀏覽
添加回答
舉報(bào)
0/150
提交
取消