亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Angular2-可以在模板中訪問私有變量嗎?

Angular2-可以在模板中訪問私有變量嗎?

慕妹3242003 2019-12-25 15:31:25
如果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。這也是提前編譯的特定答案。


查看完整回答
反對 回復 2019-12-25
  • 3 回答
  • 0 關注
  • 1311 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號