手机推荐

编程入门 行业动态 更新时间:2024-10-27 09:40:43

<a href=https://www.elefans.com/category/jswz/34/1769814.html style=手机推荐"/>

手机推荐

Typescript的interface、class和abstract class

interface,class,和abstract class这3个概念,既有联系,又有区别,本文尝试着结合官方文档来阐述这三者之间的关系。

1. Declaration Merging

Declaration TypeNamespaceTypeValue
NamespaceX X
Class XX
Enum XX
Interface X 
Type Alias  X
Function  X
Variable  X

首先我们来讲一下上面这张表格,当我们第一列的关键字进行声明时,我们在做什么。

namespace job {haircut(): void;
}class Man{name: string;
}
let imgss = new Man();enum Color {red, blue, yellow}interface dogfood {brand: string;price: number
}
type event = 'mouse' | 'keyboard';function foo(){}let a = 2;
var b = {};
const c = null;

namespace用来声明一个命名空间,比较著名的命名空间有亚博lodash,里面有一堆体育app工具函数,统统放在一个叫_的namespace里面,同时你也可以let $ = _;所以namespace也声明了一个值。

class声明了一个值,也声明了一种类型,你可以把Man赋值给一个变量,所以class是一种值,也可以说imgss是一个Man(类型),此时Man承担了一种类型的角色。

enum声明了一个值,也声明了一种类型。我们说red是一种Color,Color在这里承担类型的角色,也可以把Color赋值给一个变量

interface声明了一种类型,但是你不能把dogfood赋值给某个变量,否则你会得到一个报错``dogfood' only refers to a type, but is being used as a value here`

其他function,let,var,const都在声明一个值,你 不能说xxx是一个a,或者xxx是一个foo,不能把值当成类型使用。

2. interface和class

我们知道,不算symbol,js中有6种基本类型,number,string,boolean,null, undefined, object。但是只依靠这几种类型,来描述某个函数需要传什么样的参数,是远远不够的,这也是interface的使命--描述一个值(value)的形状(type)。

现在我们来看class,class首先也具有interface的能力,描述一个形状,或者说代表一种类型。此外class还提供了实现,也就是说可以被实例化;

所以class可以implements interface:

interface ManLike {speak(): void;leg: number;hand: number;
}
class Human implements ManLike {leg: number = 2;hand: number = 2;speak() {console.log('i can speak');}
}

而interface可以extends class,此时的class承担类型的角色

interface Chinese extends Human {country: string;
}

那么interface能不能extends enum或者type alias呢,这两个兄弟也声明了type啊,答案是不行的,官方报错的信息:

An interface can only extend an object type or intersection of object types with statically known members.

3. class和abstract class

class和abstract class的区别主要是abstract class不能被实例化:

abstract Human {name: string;abstract lang(): void;toString() {return `<human:${this.name}>`}
}
new Human // Cannot create an instance of an abstract class.

4. interface和abstract class

两者都不能被实例化,但是abstract class 也可以被赋值给变量。
interface 里面不能有方法的实现,abstract class 可以提供部分的方法实现,这些方法可以被子类调用。

更多推荐

手机推荐

本文发布于:2023-06-30 17:39:12,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/963832.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:手机

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!