TypeScript での取得と設定 質問する

TypeScript での取得と設定 質問する

プロパティの get メソッドと set メソッドを作成しようとしています:

private _name: string;

Name() {
    get:
    {
        return this._name;
    }
    set:
    {
        this._name = ???;
    }
}

値を設定するキーワードは何ですか?

ベストアンサー1

TypeScript は、ECMAScript4/ActionScript3 のような getter/setter 構文を使用します。

class foo {
    private _bar: boolean = false;
    get bar(): boolean {
        return this._bar;
    }
    set bar(value: boolean) {
        this._bar = value;
    }
}

ただし、これを使用するには、TypeScript コンパイラが ECMAScript5 以上をターゲットにしていることを確認する必要があります。コマンドライン コンパイラを実行している場合は、--target次のようなフラグを使用します。

tsc --target ES5

Visual Studioを使用している場合は、プロジェクトファイルを編集して、TypeScriptCompileビルドツールの構成にフラグを追加する必要があります。ここ:

これにより、ECMAScript 5 のObject.defineProperty()機能を使用して、この JavaScript が生成されます。

var foo = (function () {
    function foo() {
        this._bar = false;
    }
    Object.defineProperty(foo.prototype, "bar", {
        get: function () {
            return this._bar;
        },
        set: function (value) {
            this._bar = value;
        },
        enumerable: true,
        configurable: true
    });
    return foo;
})();

EcmaScript の最新バージョンでは、元の TypeScript に似たコードが生成されます。たとえば、EcmaScript2017 をターゲットにすると、次のコードが生成されます。

"use strict";
class foo {
    constructor() {
        this._bar = false;
    }
    get bar() {
        return this._bar;
    }
    set bar(value) {
        this._bar = value;
    }
}

それを使用するには、

var myFoo = new foo();
if(myFoo.bar) {         // calls the getter
    myFoo.bar = false;  // calls the setter and passes false
}

@DanFromGermany が以下で示唆しているように、 のようなローカル プロパティを単に読み書きする場合foo.bar = true、セッターとゲッターのペアはやりすぎです。プロパティが読み書きされるたびにログに記録するなどの操作を行う必要がある場合は、いつでも後で追加できます。

ゲッターは読み取り専用プロパティを実装するために使用できます。以下は、ゲッターが読み取り専用型およびオプション型とどのように相互作用するかを示す例です。

//
// type with optional readonly property.
// baz?:string is the same as baz:string|undefined
//
type Foo = {
    readonly bar: string;
    readonly baz?: string;
}
const foo:Foo = {bar: "bar"}
console.log(foo.bar) // prints 'bar'
console.log(foo.baz) // prints undefined

//
// interface with optional readonly property
//
interface iFoo {
    readonly bar: string;
    readonly baz?: string;
}

const ifoo:iFoo = {bar: "bar"}
console.log(ifoo.bar)  // prints 'bar'
console.log(ifoo.baz)  // prints undefined


//
// class implements bar as a getter, 
// but leaves off baz.
//
class iBarClass implements iFoo {

    get bar() { return "bar" }
}
const iBarInstance = new iBarClass()
console.log(iBarInstance.bar) // prints 'bar'
console.log(iBarInstance.baz) // prints 'undefined'
// accessing baz gives warning that baz does not exist 
// on iBarClass but returns undefined
// note that you could define baz as a getter
// and just return undefined to remove the warning.


//
// class implements optional readonly property as a getter
//
class iBazClass extends iBarClass {
    private readonly _baz?: string

    constructor(baz?:string) {
        super()
        this._baz = baz
    }

    get baz() { return this._baz; }
}

const iBazInstance = new iBazClass("baz")
console.log(iBazInstance.bar)  // prints bar
console.log(iBazInstance.baz)  // prints baz

おすすめ記事