TypeScript 中的 interface 与 class 有何不同?

阅读时长 4 分钟读完

在 TypeScript 中,interfaceclass 是两个非常重要的概念。它们都用于描述类型,并且在编写可维护、可扩展的代码时非常有用。然而,它们之间还是存在一些区别的。本文将会介绍这些区别,以及如何在实际开发中合理选择使用它们。

interface

interface 是 TypeScript 中用于描述类型的关键字。它可以用于声明对象、函数等各种类型。

-- -------------------- ---- -------
--------- ---- -
  ----- -------
  ---- -------
-

----- ----- ---- - -
  ----- --------
  ---- --
-

上述代码中,User 就是一个接口,它描述了一个拥有 nameage 字段的对象。通过给 user 变量指定类型为 User,我们可以在编译时就验证 user 的结构是否符合 User 接口的要求。

除了对象,interface 还可以用于描述函数类型。

上述代码中,Add 描述了一个函数,它接收两个参数 ab,返回值为它们的和。我们可以通过将 add 变量的类型指定为 Add,来告诉 TypeScript 这个变量应该是一个函数,并且应该符合 Add 描述的签名。

class

class 是 TypeScript 中用于定义对象的类。它包含了构造函数、属性和方法等元素。

-- -------------------- ---- -------
----- ------ -
  ------- ------ -------
  ------- ----- -------

  ----------------- ------- ---- ------- -
    ---------- - -----
    --------- - ----
  -

  --- ------ -
    ------ -----------
  -

  --- ----------- ------- -
    ---------- - ------
  -

  --- ----- -
    ------ ----------
  -

  --- ---------- ------- -
    --------- - ------
  -
-

----- ------ - --- --------------- ----

上述代码中,Person 是一个类,它包括了 nameage 两个属性,以及对这两个属性进行读写的 gettersetter 方法。constructor 方法则定义了该类的构造函数,在创建实例时被调用。

interface 不同,class 不仅仅是一种描述类型的方式,它还包含了代码执行上的内容。通过实例化类,我们可以创建一个具有一定行为和状态的对象。

interface 和 class 的区别

interfaceclass 的区别在于它们所描述的类型的不同。interface 仅仅是一种描述类型的方式,它不包含功能实现,所以它无法通过 new 关键字被实例化成一个对象。而 class 则不仅描述了类型,还包含了属性和方法等具体实现的内容,可以被实例化成一个具体的对象。

此外,interface 中的属性和方法默认都是公共的,而 class 中的属性和方法可以通过 private public protected 关键字来控制访问性。这是 interfaceclass 另一个重要的区别。

如何选择

在实际开发中,应该根据具体情况选择使用 interface 还是 class

如果只需要描述类型,那么使用 interface 就足够了,因为它比 class 更轻量级、更简单。

如果需要描述既有类型,又有一定的功能实现,那么使用 class 是比较明智的选择,因为它可以帮助更好地封装和组织代码,提高代码的可维护性和可扩展性。

总结

本文介绍了 TypeScript 中 interfaceclass 的区别,它们在描述类型及包含实现细节方面有所不同。我们应该根据具体情况选择使用它们。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/664f1a77d3423812e4014fe5

纠错
反馈