TypeScript class 的访问控制
默認的控制權限是 public.public 屬性的字段和方法,可以在 class 外部被訪問。
class Greeter {public greet() {console.log("hi!");} } const g = new Greeter(); g.greet();因為 public 已經是默認的可見性修飾符,所以你不需要將它寫在類成員上,但可能出于樣式/可讀性原因選擇這樣做。
protected
受保護的成員僅對聲明它們的類的子類可見。
Exposure of protected members
派生類需要遵循其基類契約,但可以選擇公開具有更多功能的基類子類型。 這包括公開受保護的成員:
class Base {protected m = 10; } class Derived extends Base {// No modifier, so default is 'public'm = 15; } const d = new Derived(); console.log(d.m); // OK請注意,Derived 已經能夠自由地讀取和寫入 m,因此這不會有意義地改變這種情況的“安全性”。 這里要注意的主要事情是,在派生類中,如果這種暴露不是故意的,我們需要小心地重復受保護的修飾符。
private
private 類似于 protected,但不允許從子類訪問成員:
上述例子表明我們不能在子類里將父類的 private 屬性提升成 protected 或者 public.
子類也無法訪問父類的 private 字段。
Cross-instance private access
在 TypeScript 類實例內部,一個實例能訪問其他實例的私有字段嗎?答案是可以。
class A {private x = 10;public sameAs(other: A) {// No errorreturn other.x === this.x;} }TypeScript class 訪問控制的鏡花水月
與 TypeScript 類型系統的其他方面一樣,private 和 protected 僅在類型檢查期間強制執行。 這意味著 JavaScript 運行時構造(如 in 或簡單屬性查找)仍然可以訪問私有或受保護成員。
class MySafe {private secretKey = 12345; } Try // In a JavaScript file... const s = new MySafe(); // Will print 12345 console.log(s.secretKey);上面這段 TypeScript 代碼雖然有語法錯誤,但是編譯成 JavaScript 之后,仍然能夠成功執行,訪問到 s 的 secretKey 字段。
更多Jerry的原創文章,盡在:“汪子熙”:
總結
以上是生活随笔為你收集整理的TypeScript class 的访问控制的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 飞机7700紧急代码是什么意思(专注动漫
- 下一篇: SAP Fiori Elements 公