Typescript中补充的六个类型

在TypeScript中,有六种新增的类型,它们分别是:

  1. 交叉类型(Intersection Types)
  2. 元组类型(Tuple Types)
  3. 派生类型(Derived Types)
  4. 泛型类型(Generic Types)
  5. 类型别名(Type Aliases)
  6. 类型断言(Type Assertion)

下面我们将逐一介绍这些类型,并提供相应的示例代码。

  1. 交叉类型(Intersection Types)

交叉类型是将多个类型合并为一个新类型。新类型具有所有类型的特性。




interface A {
  x: number;
}
 
interface B {
  y: string;
}
 
type C = A & B;
 
let c: C = { x: 1, y: "Hello" };
  1. 元组类型(Tuple Types)

元组类型允许表示一组固定长度的已知类型的值。




let tuple: [string, number];
tuple = ["Hello", 10]; // OK
// Error: Element at index 1 is not assignable to the type 'number'.
tuple = [10, "Hello"]; 
  1. 派生类型(Derived Types)

派生类型是基于已有类型创建新类型的过程。




class A {
  x = 10;
}
 
type B = A;
 
let b: B = new B(); // Error: 'B' is an alias for 'A' which is a class.
  1. 泛型类型(Generic Types)

泛型类型允许定义可以在创建类或函数时指定类型的类或函数。




function identity<T>(arg: T): T {
  return arg;
}
 
let result = identity<string>("Hello"); // Type of result is 'string'.
  1. 类型别名(Type Aliases)

类型别名允许创建一个新的名字来引用一个类型。




type A = number;
let b: A;
b = 10; // OK
// Error: Type 'string' is not assignable to type 'number'.
b = "Hello"; 
  1. 类型断言(Type Assertion)

类型断言允许你明确地指定一个类型。




let someValue: any = "Hello";
let strLength: number = (<string>someValue).length;

以上就是Typescript中补充的六种类型,以及它们的使用示例。

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日