LoginSignup
45
49

More than 5 years have passed since last update.

TypeScriptのstaticアクセス修飾子を使う時理解する4つの事

Last updated at Posted at 2015-09-23

TypeScriptのstaticアクセス修飾子を理解する4つの事

publicとprivateはなんとなくわかるのですが、たまーにstaticってどういう役割なんだっけなって(ちょっと恥ずかしいけど)なるので(protectはいいや)
この際意識の上に上げる。。

下記ようなコードを書きました。
Errorです

やりたい事

「インスタンスメソッド経由でstaticメソッドを呼び出し別のstaticメンバの値を取得すること」

※このコードのどこが悪いかお気付きの方はさようなら。東京行っても頑張ってください。

下記のコード:TypeScriptPlayground

class Faa {
    static named : string = 'eee';
    constructor(private name?: string){
    }
    get getName() : string{
        return this.name
    }
    set getName(name:string){
        this.name = name;
    }
    static main(){
        alert(Faa.named)
    }
}
Faa.main()//ok //e.g
var h1 = new Faa()
h1.main()//Error
//typescript compile Error → property 'main' does not exist on type of Faa 
//consoleError → "h1.main is not a function" 

getter、setterとかはダミーです

static

①クラスに紐づくメンバ(静的メンバ)
②アクセスは「Class名.メンバ名」。非static内からの呼び出す場合もこの記述
③static内からstaticなメンバにアクセスするには「this.メンバ名」
④静的メンバは型引数を参照できない

staticだと何が嬉しいのか

・インスタンスを生成しなくても静的メソッドを実行できる(上のコードの「//ok //e.g」部分)
・同じクラスから生成されたインスタンスが静的メンバを共有できる(下で説明)

つまり僕はこうしなくてはいけなかったんです。
下記のコード:TypeScriptPlayground

class Faa {
    static named : string = 'eee';
    constructor(private name?: string){
    }
    get getName() : string{
        return this.name
    }
    set getName(name:string){
        this.name = name;
    }
//追加/////////
    public main(){//インスタンスメソッド経由で呼び出す
        Faa.main()
    }
//////////////
    static main(){
        alert(Faa.named)
    }
}
var h1 = new Faa()
h1.main()

パブリックなインスタンスメンバを経由して静的メンバへアクセスする。
なんかget,setに似てる。。

生成されたJSをみると紐づくオブジェクトが違うね

    Faa.prototype.main = function () {//public
        Faa.main();
    };
    Faa.main = function () {//static
        alert(Faa.named);
    };

「同じクラスから生成されたインスタンスが静的メンバを共有できる」ってなあに?

こうだよ
下記のコード:TypeScriptPlayground

interface Iman{
    giveManey(): number;
}
class Man<T> implements Iman{
    static saifcontent :number = 0;
    static giveManey<T>(maney:number){
        this.saifcontent += maney;
    }
    public giveManey<T>(){
        return Man.saifcontent;
    }
}
Man.giveManey(1000);//1000
var dd = new Man<number>()
console.log(dd.giveManey())//別インスタンスでもこの時点でstatic財布を共有している。1000
Man.giveManey(2000);//3000
var cc = new Man();
console.log(cc.giveManey())//別インスタンスでもこの時点でstatic財布を共有しているので3000
Man.giveManey(500);//3500

alert(Man.saifcontent);

同じ親クラスから派生したインスタンスが変化する親クラスのstaticの値を共有していることがわかります。

「静的メンバは型引数を参照できない」ってなあに?

なるほど。。

class X<T>{
  static a:T;//static menbers cannot reference class type paramerters
}

staticなメンバーはclass型のパラメーターを参照できないってエラーでます。
staticにこういうことはやりませんよね。

まとめ(TypeScriptのstaticアクセス修飾子を理解する4つの事)

①クラスに紐づくメンバ(静的メンバ)
②アクセスは「Class名.メンバ名」。非static内からの呼び出す場合もこの記述
③static内からstaticなメンバにアクセスするには「this.メンバ名」
④静的メンバは型引数を参照できない

最後に

staticをマヨつけて食べたい

45
49
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
45
49