- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有一个 very similar question ,但是对于文档中提到的静态端和实例端没有直接的答案。
正如我依稀理解的那样,静态端是构造函数,实例端是其他一切?
来自 typescript documentation 的一个例子:
interface ClockConstructor {
new (hour: number, minute: number): ClockInterface;
}
interface ClockInterface {
tick(): void;
}
function createClock(ctor: ClockConstructor, hour: number, minute: number): ClockInterface {
return new ctor(hour, minute);
}
class DigitalClock implements ClockInterface {
constructor(h: number, m: number) { }
tick() {
console.log("beep beep");
}
}
class AnalogClock implements ClockInterface {
constructor(h: number, m: number) { }
tick() {
console.log("tick tock");
}
}
let digital = createClock(DigitalClock, 12, 17);
let analog = createClock(AnalogClock, 7, 32);
最佳答案
计算机科学中的命名是出了名的困难。
在 TypeScript 中,我们通常使用同名来指代类的构造函数(它是一个在运行时存在的值),并作为类的实例的类型(它只在设计时存在,不会发出到JavaScript)。
所以在
class Foo { }
const foo: Foo = new Foo();
有一个名为
Foo
的类构造函数,它可以用来构造我们称之为
Foo
类型的类实例。
Foo
构造
Foo
实例”可能会令人困惑。就这样吧,我猜。
Foo
对应于实例侧的形状。要获取静态端的类型,我们可以使用
typeof
type query operator 对名为
Foo
的构造函数值进行操作:
typeof Foo
。所以,
Foo
是实例端类型,
typeof Foo
是静态端类型。
Foo
来展示它是如何工作的:
class Foo {
instanceProp: string;
constructor(constructorArgument: string) {
this.instanceProp = constructorArgument;
}
instanceMethod(): void {
console.log("Instance method called on " + this.instanceProp)
}
static staticProp: string = "Static Thing";
static staticMethod(): void {
console.log("Static method called on " + this.staticProp)
}
}
这是一个单一的类定义,但它有静态端和实例端。
Foo
的静态部分,即与其构造函数有关的内容,包括:
{new(constructorArgument: string): Foo}
staticProp
属性,其类型为 string
和 staticMethod
方法,其签名为 {(): void}
。 typeof Foo
,但您实际上可以根据需要为其定义自己的接口(interface),如下所示:
interface StaticSideOfFoo {
new(constructorArgument: string): Foo;
staticProp: string;
staticMethod(): void;
}
Foo
的实例端,即与其实例相关的内容,包括:
instanceProp
属性,其类型为 string
和 instanceMethod
方法,其签名为 {(): void}
。 Foo
,您也可以为此定义自己的接口(interface):
interface InstanceSideOfFoo {
instanceProp: string;
instanceMethod(): void;
}
const foo1 = new Foo("Number 1");
console.log(foo1.instanceProp); // Number 1
foo1.instanceMethod(); // Instance method called on Number 1
const foo2 = new Foo("Number 2");
console.log(foo2.instanceProp); // Number 2
foo2.instanceMethod(); // Instance method called on Number 2
console.log(Foo.staticProp); // Static Thing
Foo.staticMethod(); // Static method called on Static Thing
请注意,
foo1
和
foo2
无法直接访问构造函数签名或
staticProp
或
staticMethod
:
new foo1("oops"); // error!
foo1.staticProp; // error!
foo1.staticMethod(); // error!
并且
Foo
不能直接访问
instanceProp
或
instanceMethod
:
Foo.instanceProp; // error!
Foo.instanceMethod(); // error!
foo1
和
foo2
的类型为
Foo
,类似于
InstanceSideOfFoo
,而值
Foo
的类型为
typeof Foo
,类似于
StaticSideOfFoo
。我们可以在这里验证:
const instanceSideOfFoo: InstanceSideOfFoo = foo1; // okay
const instanceSideOfFooOops: InstanceSideOfFoo = Foo; // error!
const staticSideOfFoo: StaticSideOfFoo = Foo; // okay
const staticSideOfFooOops: StaticSideOfFoo = foo1; // error!
Foo
构造函数的函数,你想谈论
typeof Foo
或
StaticSideOfFoo
或
new (x: string)=>Foo
,而如果你想制作一个接受
Foo
实例的函数,你想谈论
Foo
或
InstanceSideOfFoo
或
{instanceProp: string}
,等等。
关于typescript - typescript 中的 'static side' 和 'instance side' 到底是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58399613/
我知道我的问题有点含糊,但我不知道如何描述它。我问过很多地方,但似乎没有人理解我为什么要这样做。但请耐心等待,我会解释为什么我想要这样的东西。 我使用 Liquid Templates 允许用户在我的
这个问题在这里已经有了答案: what is the difference between null != object and object!=null [duplicate] (2 个回答) 7年
当我在我的本地主机 Google App Engine 应用程序中将日志记录级别更改为 FINE 时,我开始在我的跟踪堆栈中看到这些: Apr 17, 2013 4:54:20 PM com.goog
Python 有内置函数 type : class type(object) With one argument, return the type of an object. The return v
我正在使用深度学习进行语义分割,我遇到了以下术语:语义分割、实例检测、对象检测 和对象分割. 它们有什么区别? 最佳答案 这些术语的某些用法对用户而言是主观的或依赖于上下文,但据我所知对这些术语的合理
我面临 -[NSConcreteMutableData release] 的问题:消息发送到已释放的实例,我也附上了我的示例代码。 - (IBAction)uploadImage { NSString
我试图显示模型中的单个实例(数据库行),其中多个实例共享多行的相同字段(列)值。为了澄清这一说法,我有以下情况: ID/Title/Slug/Modified 1 Car A 1s ag
我正在尝试使用mockito来模拟服务。然而,我没有找到一种方法来告诉mockito,给定一个类的实例返回给我相同的实例: 类似于: given(service.add(any(Individua
我知道如何从父类(super class)原型(prototype)创建子类原型(prototype)。但是,如果我已经有了父类(super class)对象的实例来创建子类对象怎么办? 在 JS 中
鉴于 Kotlin 1.1。对于某个类的 instance,instance::class.java 和 instance.javaClass 似乎几乎是等价的: val i = 0 println(
这个问题在这里已经有了答案: 8年前关闭。 Possible Duplicate: Find out the instance id from within an ec2 machine 我正在寻找从
为什么我的 Instantiate 函数没有创建 That 的“空白”实例? 我有以下最小类: classdef That < handle properties This = '' end
Session session = HibernateUtil.getSessionFactory().openSession(); Transaction tx = session.beginTra
考虑以下几点: public class A { public String name = "i am a A instance"; } public class B extends A {
我正在使用 Scalr 来扩展网站服务器。 在 Apache 服务器上,我安装了 Sakai,并为 Linux 机器创建了一个启动脚本。 问题是,如何确保MySQL实例在Apache服务器启动之前启动
Android Realm DB 允许使用 Realm.getInstance() 获取多个实例。这些中的最佳实践是什么? :1.创建单个实例(应用程序范围)并在任何地方使用它2. 在需要时获取一个新
我很难理解为什么修改实例 a 中的属性会修改实例 b 中的相同属性。 var A = function (){ }; A.prototype.data = { value : 0 }; var
我将 Weka 用作更长管道的一部分,因此,我无法承受将所有数据写入文件或数据库只是为了创建一个 Instances。目的。我可以即时做的是创建 Instance 的列表对象。 来自 this pag
class C: def func(self, a): print(a) c = C() print(c.__dict__) # {} c.func = c.func # c.func i
Angular Routing 文档提到了组件实例创建、组件实例激活和路由激活。 文档没有解释这些概念的区别,以及每次创建/激活发生的时间。 问题 实例创建和实例激活有什么区别? 实例激活和路由激活有
我是一名优秀的程序员,十分优秀!