1. 什么是TypeScript:
Typed JavaScript at Any Scale. 添加了类型系统的 JavaScript,适用于任何规模的项目。
TypeScript 是添加了类型系统的 JavaScript,适用于任何规模的项目。TypeScript 是一门静态类型、弱类型的语言。
TypeScript 是完全兼容 JavaScript 的,它不会修改 JavaScript 运行时的特性。
TypeScript 可以编译为 JavaScript,然后运行在浏览器、Node.js 等任何能运行 JavaScript 的环境 中。
TypeScript 拥有很多编译选项,类型检查的严格程度由你决定。
TypeScript 可以和 JavaScript 共存,这意味着 JavaScript 项目能够渐进式的迁移到 TypeScript。
TypeScript 增强了编辑器(IDE)的功能,提供了代码补全、接口提示、跳转到定义、代码重构等 能力。
TypeScript 拥有活跃的社区,大多数常用的第三方库都提供了类型声明。
TypeScript 与标准同步发展,符合最新的 ECMAScript 标准(stage 3)。
2.ts与js的区别:
TypeScript 是 JavaScript 的超集,扩展了 JavaScript 的语法,因此现有的 JavaScript 代码可与 TypeScript 一起工作无需任何修改,TypeScript 通过类型注解提供编译时的静态类型检查。TypeScript对js中的ts进行编译,注意只是编译以及限制数据类型,在编译中体现,不会对ts运行。
3. 安装TypeScript命令行工具:
一般而言,ts都是编译成js后再执行js,如果想一步到位,可以安装ts-node
npm install -g typescript
4.基础数据类型:
在js中,分基础数据类型和引用数据类型。
基础类型有:string、boolean、number、null、undefined
引用数据类型:function、array、object。
在ts中:
基础类型有:string、boolean、number、null、undefined
此处不要使用String、Boolean、Number等,这几个表示的是构造函数,不是基础数据类型。
TypeScript 程序由以下几个部分组成:
- 模块
- 函数
- 变量
- 语句和表达式
- 注释
ts要比js严格:
//这种写法ts会报错,而在js是可以的 let str="lengyuexin"; str=1024
原因是因为str初始化的值是字符串,赋个其他类型的数据,所以报错
正确的写法:
let str="lengyuexin"; str="1024"
接口声明合并:
接口中的属性在合并时会简单的合并到一个接口中:
interface Alarm { price: number; } interface Alarm { weight: number; }
相当于:
interface Alarm { price: number; weight: number; }
限制类型基础:
function sayHello(text: string) {// 在 TypeScript 中,我们使用 : 指定变量的类型 return `hello ${text} !`; } let text = "world"; console.log(sayHello(text));