如果private在組件類上聲明了變量,我是否應該能夠在該組件的模板中訪問它?@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貢獻1872條經驗 獲得超4個贊
不,您不應該在模板中使用私有變量。
雖然我喜歡drewmoore的答案,并且看到了完美的概念邏輯,但在實現上卻是錯誤的。模板不存在于組件類中,而是在它們之外。查看此回購作為證明。
它起作用的唯一原因是因為TypeScript的private關鍵字并未真正使成員私有。即時編譯在運行時在瀏覽器中進行,并且JS沒有任何私有成員的概念(還可以嗎?)。幸得桑德埃利亞斯為把我在正確的軌道上。
使用ngc和提前編譯,如果嘗試從模板訪問組件的私有成員,則會出現錯誤。克隆演示倉庫,將MyComponent成員的可見性更改為private,運行時將出現編譯錯誤ngc。這也是提前編譯的特定答案。
- 3 回答
- 0 關注
- 1311 瀏覽
添加回答
舉報
0/150
提交
取消