gpt4 book ai didi

javascript - Typescript 中这段代码的意义何在?

转载 作者:搜寻专家 更新时间:2023-10-30 20:59:17 24 4
gpt4 key购买 nike

我正在阅读 Typescript 手册,我注意到部分代码(对我而言)毫无意义。有人可以解释一下这是什么目的吗?

取自docs :

class Greeter {
static standardGreeting = "Hello, there";
greeting: string;
greet() {
if (this.greeting) {
return "Hello, " + this.greeting;
}
else {
return Greeter.standardGreeting;
}
}
}

var greeter1: Greeter;
greeter1 = new Greeter();
alert(greeter1.greet());

var greeterMaker: typeof Greeter = Greeter; // This line
greeterMaker.standardGreeting = "Hey there!"; // This line
var greeter2:Greeter = new greeterMaker(); // And this line
alert(greeter2.greet());

因此,文档所说的是 var greeterMaker: typeof Greeter = Greeter “将自己持有类。”我也不完全确定那是什么意思

然后它会这样做:

greeterMaker.standardGreeting = "Hey there!";

// Which does the exact same thing as this:
Greeter.standardGreeting = "Hey there!";

我在这里错过了什么?

最佳答案

这部分文档似乎试图解释Greeting 类型和typeof Greeting 类型之间的区别。

要了解这两件事,您必须首先了解 TypeScript 类是结合了 (1) 构造函数和 (2) 描述由该构造函数生成的实例的接口(interface)的语法糖。

所以,当你看到这个时:

class Greeter {
static standardGreeting = "Hello, there";
greeting: string;
greet() {
// ... code ...
}
}

你实际上在做的是定义一些东西,手写的,看起来更像这样:

interface Greeter {
greet(): void;
}

var Greeter: {
new(): Greeter;
prototype: Greeter;
standardGreeting: string;
};

Greeter = function () {};
Greeter.prototype.greet = function () {
// ...code...
};

换句话说,您已经编写了一个描述 Greeter 实例的接口(interface) Greeter,以及变量 Greeter 上的第二个匿名 类型描述了构造函数。 (这是有效的,因为类型存在于一个单独的并行命名空间中,该命名空间与生成的代码中的变量名称不冲突。)

使用 Greeter 接口(interface)类型是很明显的——只需编写 Greeter——但是如何访问附加到 Greeter 变量的匿名类型?答案是 typeof 类型修饰符。编写 typeof Greeter 表示“使用 variable Getter 的类型”,这让我们可以访问分配给变量 Greeter 的匿名类型,该变量保存构造函数。

这就是文档试图解释的内容。希望这个解释更清楚,我们现在可以理解这部分代码:

// This creates an alias called `greeterMaker` to the
// Greeter constructor function
// (functions are objects, and objects are always handled
// by-reference in JavaScript)
var greeterMaker: typeof Greeter = Greeter;

// This modifies the `standardGreeting` property of the
// function through the alias
greeterMaker.standardGreeting = "Hey there!";

// This invokes the constructor function through the alias,
// constructing a new instance of a Greeter
var greeter2:Greeter = new greeterMaker(); // And this line

关于javascript - Typescript 中这段代码的意义何在?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34754727/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com