快速开始 - TypeScript 入门指南

环境安装

为了学习使用 TypeScript,你首先要把 TypeScript 编译工具安装到你的本地环境中。打开终端执行以下命令:

复制代码
npm install -g typescript

Tips:如果你无法使用 npm 命令,请确保你本地已安装了 Node 环境。Mac 电脑可能会需要用到 sudo 命令。

安装完成后,你可以通过 tsc -v 命令进一步确认 TypeScript 是否成功安装。正常情况下,它将输出你当前安装的 TypeScript 版本信息。

编写代码

环境准备就绪后,你可以尝试打开编辑器新建一个如下内容的 greet.ts 文件:

function 复制代码
    console.log(`hello ${ what }`);
}

greet("world");

然后将终端命令行切换到该文件目录下,执行 tsc greet.ts 编译命令。如果你是首次编译 该文件,目录里会输出一个同名的 greet.js 文件。否则,编译器将更新该文件。

类型注解

或许你注意到了,上面的代码和 JavaScript 代码是一致的。接下来让我们更新一下这个文件:

function 复制代码
    console.log(`hello ${ what }`);
}

greet({ name: "world" });

你这里看到的 what: string 是 TypeScript 独有的一种写法,被称为类型注解 。这是 TypeScript 提供的一种轻量级的为函数或变量添加约束 的方式,语法结构为 <target>:<type>。其中 <targert> 是约束目标,可以是对象、函数等任意 JavaScript 值;<type> 是约束方式,可以是 JavaScript 的原始类型、构造函数或者你创建的自定义类。

类型契约

重新编译这个更新后的文件,你会看到编译器终端向你报告了一个错误。

Argument 复制代码

这就是 TypeScript 为 JavaScript 提供的功能------类型约束。

现在假定 greet() 是一个第三方提供的 API,你无法对它做出修改。为了修复上面的编译错误,你必须greet() 传入一个 string 类型的参数。

当然,如果情况允许你修改 greet() 的定义,你可以重构 greet() 如下:

function 复制代码
    console.log(`hello ${ what.name }`);
}

现在,greet({ name: "world" }) 就不会编译出错了。

变量注解

类似地,你也可以在变量声明的时候,为变量添加类型上的使用约定。

let 复制代码
let student: {
    name: string;
    age: number;
};

这样之后,你就不能随便地为变量赋值,赋值必须符合定义的类型结构。

isOk 复制代码
student = { name: "小明" }; // Error
student = { name: "小明", age: 20 }; // Okay

可以看到,TypeScript 提供的类型安全其实就是描述了什么样的值是可以被安全传递的。

相关推荐
陈随易9 分钟前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart1 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒3 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰3 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
竹林8184 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
妙码生花4 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
Awu12275 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
咪库咪库咪5 小时前
Vue3-生命周期
前端
莪_幻尘6 小时前
你的 AI Skill 越多越蠢?Token 上下文爆炸的求生指南
前端·ai编程
lichenyang4536 小时前
从 has.echo 到异步 API 注册表:一次 ASCF API 回调不触发的排查复盘
前端