typescript
- JavaScript的超集,最终会被编译为JavaScript代码,主要提供了类型系统和对 ES6+ 的支持
- 特点
- 始于JavaScript,归于JavaScript
- 强大的类型系统
- 先进的 JavaScript
- 安转
npm install -g typescript
tsc -V
src/helloworld.ts
function greeter (person) {
return 'Hello, ' + person
}
let user = 'Yee'
console.log(greeter(user))
- 运行生成helloworld.js 文件
tsc helloworld.ts
- 自动编译
1). 生成配置文件tsconfig.json
tsc --init
2). 修改tsconfig.json配置
"outDir": "./js",
"strict": false,
3). 启动监视任务:
终端 -> 运行任务 -> 监视tsconfig.json
- 添加类型注解
function greeter (person: string) {
return 'Hello, ' + person
}
let user = 'Yee'
//报错 尽管有错误,greeter.js 文件还是被创建了
//let user = [0, 1, 2]
console.log(greeter(user))
- 接口
interface Person {
firstName: string
lastName: string
}
function greeter (person: Person) {
return 'Hello, ' + person.firstName + ' ' + person.lastName
}
let user = {
firstName: 'Yee',
lastName: 'Huang'
}
console.log(greeter(user))
- TypeScript 支持 JavaScript 的新特性,比如支持基于类的面向对象编程。
class User {
fullName: string
firstName: string
lastName: string
constructor (firstName: string, lastName: string) {
this.firstName = firstName
this.lastName = lastName
this.fullName = firstName + ' ' + lastName
}
}
interface Person {
firstName: string
lastName: string
}
function greeter (person: Person) {
return 'Hello, ' + person.firstName + ' ' + person.lastName
}
let user = new User('Yee', 'Huang')
console.log(greeter(user))
- TS基础类型
let a:string = 'hello'
function fn():void{
console.log('hello")
}
- 联合类型
function toString2(x: number | string) : string {
return x.toString()
}
function getLength(x: number | string) {
// return x.length // error
if (x.length) { // error
return x.length
} else {
return x.toString().length
}
}
- 类型断言好比其它语言里的类型转换
/*
类型断言(Type Assertion): 可以用来手动指定一个值的类型
语法:
方式一: <类型>值
方式二: 值 as 类型 tsx中只能用这种方式
*/
/* 需求: 定义一个函数得到一个字符串或者数值数据的长度 */
function getLength(x: number | string) {
if ((<string>x).length) {
return (x as string).length
} else {
return x.toString().length
}
}
console.log(getLength('abcd'), getLength(1234))
- 类型推断
/* 定义变量时赋值了, 推断为对应的类型 */
let b9 = 123 // number
// b9 = 'abc' // error
/* 定义变量时没有赋值, 推断为any类型 */
let b10 // any类型
b10 = 123
b10 = 'abc'
TypeScript 的核心原则之一是对值所具有的结构进行类型检查。我们使用接口(Interfaces)来定义对象的类型。接口是对象的状态(属性)和行为(方法)的抽象(描述)
/*
在 TypeScript 中,我们使用接口(Interfaces)来定义对象的类型
接口: 是对象的状态(属性)和行为(方法)的抽象(描述)
接口类型的对象
多了或者少了属性是不允许的
可选属性: ?
只读属性: readonly
*/
/*
需求: 创建人的对象, 需要对人的属性进行一定的约束
id是number类型, 必须有, 只读的
name是string类型, 必须有
age是number类型, 必须有
sex是string类型, 可以没有
*/
// 定义人的接口
interface IPerson {
id: number
// 在属性名前用 readonly 来指定只读属性
//readonly id: number
name: string
age: number
sex: string
// sex?: string
// sex: '男' // 可以没有
}
const person1: IPerson = {
id: 1,
name: 'tom',
age: 20,
sex: '男'
}
person2.id = 2 // error