前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >初识 TypeScript

初识 TypeScript

作者头像
很酷的站长
发布2022-12-28 15:50:28
8770
发布2022-12-28 15:50:28
举报
文章被收录于专栏:站长的编程笔记

1. TypeScript 是什么 ?

编程语言的类型: 静态类型语言、动态类型语言

静态类型语言的数据类型是在编译期间检查的。也就是说,在编写程序时就要声明变量的数据类型。如: Java

动态类型语言是指在运行期间才去做数据类型检查的语言。也就是说,永远不用给变量指定数据类型。如: Python、PHP

TypeScript 究竟是什么 ?

typescript 官网: https://typescriptlang.org

TypeScript 是 Type 和 JavaScript 的结合,TypeScript 就是将不看重类型的动态语言 JavaScript,变成关注类型的静态语言

2. 为什么要学习 TypeScript ?

程序更容易理解

ts 可以约定函数或方法输入输出的参数类型,外部条件等

效率更高

在不同的代码块和定义中进行跳转、代码补全、接口提示

更少的错误

编译期间能够发现大部分错误,杜绝一些比较常见的错误

3. 安装 TypeScript

全局安装 typescript

代码语言:javascript
复制
npm install -g typescript

查看版本

代码语言:javascript
复制
tsc -V

创建 helloworld.ts

代码语言:javascript
复制
const hello = (name: string) => {

编译

代码语言:javascript
复制
tsc helloworld.ts

补充: 命令行运行 ts 文件需要安装 ts-node 包

代码语言:javascript
复制
npm install -g ts-node

然后就可以使用 ts-node 命令运行 ts 文件了

代码语言:javascript
复制
ts-node helloworld.ts
4. 原始数据类型和 any 类型

最新的 ESMAScript 标准定义了八种数据类型

七种原始数据类型: number、string、boolean、undefined、null、BigInt、Symbol。另外一种是 Object

注意: undefined、null 是所有类型的子类型,所以下面写法是正确的

代码语言:javascript
复制
let age: number = undefined

顶级类型: any,可以接收所有数据类型的数据

代码语言:javascript
复制
let all: any = null;
5. 数组和元组(tuple)

声明一个 number 类型的数组,数组元素必须为 number 类型

代码语言:javascript
复制
let numArr: number[] = [1, 2, 3]

元组: 给数组元素分别指定数据类型

代码语言:javascript
复制
// 定义元组时,数组元素个数不能超过声明的类型个数
6. Interface 接口

Interface 不是 JavaScript 中的概念,而是 ts 作类型检查用的,所以 ts 在编译后,Interface 是不会被转译过去的

interface 描述对象类型

代码语言:javascript
复制
// 定义接口
7. 函数中声明数据类型

普通的声明函数,函数的结果返回 number 类型

代码语言:javascript
复制
/**

函数表达式声明的函数返回的是一个函数类型

代码语言:javascript
复制
const add = (x: number, y: number, z?: number): number => {
8. 类型推论 (type inference)

官方文档: https://www.typescriptlang.org/docs/handbook/type-inference.html

当我们把数据赋给变量时,没有指定数据类型,ts 会自动推测出一个类型,如下图:

因为 ts 已经将变量 x 的类型推断为 number,那么当我们给变量 x 赋值一个 string 类型的数据则会提示错误

9. 联合类型

代码语言:javascript
复制
// 联合类型 union types
10. 泛型 Generics

基础使用

代码语言:javascript
复制
function echo<T>(arg: T): T {

交换数组中两个元素的位置

代码语言:javascript
复制
function swap<T, U>(tuple: [T, U]): [U, T] {

约束泛型

代码语言:javascript
复制
interface ILength {
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. TypeScript 是什么 ?
  • 2. 为什么要学习 TypeScript ?
  • 3. 安装 TypeScript
  • 4. 原始数据类型和 any 类型
  • 5. 数组和元组(tuple)
  • 6. Interface 接口
  • 7. 函数中声明数据类型
  • 8. 类型推论 (type inference)
  • 9. 联合类型
  • 10. 泛型 Generics
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档