我正在尝试为属性创建 get 和 set 方法:
private _name: string;
Name() {
get:
{
return this._name;
}
set:
{
this._name = ???;
}
}
设置值的关键字是什么?
原文由 MuriloKunze 发布,翻译遵循 CC BY-SA 4.0 许可协议
我正在尝试为属性创建 get 和 set 方法:
private _name: string;
Name() {
get:
{
return this._name;
}
set:
{
this._name = ???;
}
}
设置值的关键字是什么?
原文由 MuriloKunze 发布,翻译遵循 CC BY-SA 4.0 许可协议
虽然 TypeScript 会分析属性的初始化,但如果您总是想自己处理这种情况,您可以在 — 中设置为 ts.config.json
false
对于此设置。
{
"compilerOptions": {
"strict": true,
"strictPropertyInitialization": false
}
}
严格的属性初始化 -
strictPropertyInitialization
当设置为 true 时,TypeScript 将在声明了类属性但未在构造函数中设置时引发错误。
在这种情况下,您也应该考虑其他情况,您将在下面的链接中看到。
class UserAccount {
name: string;
accountType = "user";
email: string;//Property 'email' has no initializer and is not definitely assigned in the constructor.
address: string | undefined;
constructor(name: string) {
this.name = name;
// Note that this.email is not set
}
}
this.name
具体设置。
this.accountType
默认设置。
this.email
未设置并引发错误。
this.address
被声明为可能未定义,这意味着它不必设置。
如果我们将 strictPropertyInitialization
设置为 false
,编译器不会引发错误
private _name : string;
public get name() : string {
return this._name;
}
public set name(v : string) {
this._name = v;
}
https://www.typescriptlang.org/docs/handbook/2/classes.html#–strictpropertyinitialization https://www.typescriptlang.org/tsconfig#strictPropertyInitialization
原文由 gurkan 发布,翻译遵循 CC BY-SA 4.0 许可协议
TypeScript 使用类似于 ECMAScript4/ActionScript3 的 getter/setter 语法。
这将使用 ECMAScript 5
Object.defineProperty()
功能生成这个 JavaScript。所以要使用它,
但是,为了完全使用它,您必须确保 TypeScript 编译器以 ECMAScript5 为目标。如果您正在运行命令行编译器,请使用
--target
像这样的标志;如果您使用的是 Visual Studio,则必须编辑项目文件以将标志添加到 TypeScriptCompile 构建工具的配置。你可以 在这里 看到:
正如@DanFromGermany 下面建议的那样,如果您只是读取和写入像
foo.bar = true
这样的本地属性,那么拥有一个 setter 和 getter 对就过分了。如果您需要在读取或写入属性时执行某些操作(例如日志记录),您可以随时添加它们。Getter 可用于实现只读属性。这是一个示例,它还显示了 getter 如何与只读和可选类型交互。