Typescript:基础语法学习(尚硅谷 李立超)
官方文档:https://www.tslang.cn/docs/handbook/typescript-in-5-minutes.html
搭建开发环境
npm i -g typescript
安装完成界面:
查看是否安装完成,输入以下命令:tsc
执行命令:node 文件名``
编译代码
tsc 01_HelloTs.ts
基础语法
变量声明
// 生命一个变量a,同时指定他的类型为number
let a: number
// a的类型不能修改
a = 10
a = 50
// 字符串
let b: string
b = 'hello'
// 布尔值
// let c:boolean = false
// 如果变量的声明和赋值时同时进行的,TS可以自动对变量进行类型检测
let c = false
c = true
变量定义后,类型不能修改
字面量和联合类型
// 直接使用字面量进行类型声明, 类似于常量
let a: 10
a = 10
// 可以使用|来连接多个类型(联合类型)
let b: "male"| "female"
b = "male"
b = "female"
let c: boolean|string
c = true
c = "hello"
任意值 any
可以赋予变量任意类型的值
声明变量如果不指定类型,则TS解析器会自动判断变量的类型为any
let notSure: any = 4;
notSure = "maybe a string instead";
notSure = false; // okay, definitely a boolean
断言
let e = "hello"
// 类型断言, 可以用来告诉解析器变量的实际类型
let s = e as string
s = <string>e
void 空值
// void用来表示空,以函数为例,就表示没有返回值的函数
function fn():void{
}
object 对象
// object表示一个js对象
let a: object;
a = {}
a = function () {
}
定义对象结构
// [propName:string]:any 表示任意类型的值
let c: {name:string, [propName:string]:any};
c = {name:'leo', age:18}
设置函数解构的类型声明
// 设置函数解构的类型声明
// 语法:(形参:类型,形参:类型……)=>返回值
let d: (a:number, b:number) => number
数组
// string[],表示字符串数组
let e:string[]
e = ['a', 'b', 'c']
// number[], 表示数值
let f: number[]
f = [1,2,3]
let g: Array<number>
g = [1,2,3]
枚举类型
// 枚举类型
enum Gender{
male = 0,
female = 1
}
let i: {name:string, gender:Gender}
i = {
name: '孙悟空',
gender: Gender.male
}
console.log(i.gender === Gender.male) // true
表示同时
// &表示同时
let j: {name: string} & {age:number}
j = {name: '孙悟空', age: 18}
console.log(j) //{ name: '孙悟空', age: 18 }
类型的别名
// 类型的别名
type myTye = 1|2|3|4|5
let k: myTye
k = 1
编译选项
生成tsconfig.json
tsc --init
全部编译
tsc
实时监听
tsc -w
webpack
初始化文件
npm init -y
安装依赖
npm i -D webpack webpack-cli typescript ts-loader
增加配置文件

- 添加
webpack.config.js
// 引入一个包
const path = require('path')
// webpack中的所有的配置信息都应该写在module.exports中
module.exports = {
// 指定入口文件
entry: "./src/index.ts",
// 指定打包文件所在目录
output:{
// 指定打包文件的目录
path: path.resolve(__dirname, 'dist'),
// 打包后文件的名称
filename: "bundle.js"
},
// 指定webpack打包时要使用的模块
module:{
// 指定要加载的规则
rules: [
{
// test指定的是规则生效的文件
test: /\.ts$/,
// 要使用的loader
use: 'ts-loader',
// 要排除的文件
exclude: /node-modules/
}
]
}
}
- 添加
tsconfig.json
{
"compilerOptions": {
"target": "es6",
"module": "es6",
"strict": true
}
}
- 在
package.json中添加命令脚本
"build": "webpack"

编译命令
npm run build
自动生成html文件
npm i -D html-webpack-plugin
- 文件配置
// webpack.config.js
// 引入html文件
const HTMLWebpackPlugin = require('html-webpack-plugin');
// 配置webpack插件
plugins:[
new HTMLWebpackPlugin(
{
template: './src/index.html'
}
),
]
在项目中安装浏览器
npm i -D webpack-dev-server
- 文件配置
"start": "webpack server --open chrome.exe"

- 启动命令
npm start
安装bable
npm i -D @babel/core @babel/preset-env babel-loader core-js
类实例
class Dog{
// 构造函数
constructor(name: string, age: number){
// 在实例方法中,this就表示当前的实例
// 在构造函数中当前对象就是当前新建的那个对象
// 可以通过this想新建的对象中添加属性
this.name = name
this.age = age
}
bark(){
alert("qqq")
}
}
const dog = new Dog('小河', 4)
console.log(dog) //Dog { name: '小河', age: 4 }
继承
class Animal{
// 构造函数
constructor(name: string, age: number){
this.name = name
this.age = age
}
sayHello(){
console.log("动物在叫")
}
}
// extend 继承关键字
class Dog extends Animal{
run(){
console.log(`${this.name}再跑`)
}
}
class Cat extends Animal{
}
const dog = new Dog('小河', 4)
const cat = new Cat('咪咪', 3)
console.log(dog)
dog.sayHello()
dog.run()
console.log(cat)
cat.sayHello()
运行结果如下所示:
super
简单示例
class Animal{
name : string
constructor(name:string){
this.name = name
}
sayHello(){
console.log("动物在叫~~")
}
}
class Dog extends Animal{
sayHello(){
// 在类方法中,super表示当前类的父类
super.sayHello()
}
}
const dog = new Dog("旺财")
dog.sayHello() //动物在叫~~
子类中构造函数的使用
class Animal{
name : string
constructor(name:string){
this.name = name
}
sayHello(){
console.log("动物在叫~~")
}
}
class Dog extends Animal{
age: number
constructor(name:string,age: number){
// 如果在子类中写了构造函数,在类构造函数中必须添加super方法
super() // 调用父类的构造函数
this.age = age
}
sayHello(){
// 在类方法中,super表示当前类的父类
super.sayHello()
}
}
const dog = new Dog("旺财", 3)
dog.sayHello() //动物在叫~~
抽象类
关键字 abstract
/*
以abstract开头的类是对象类
抽象类和其他类区别不大,只是不能用来创建对象
抽象类就是专门用来被继承的类
抽象类中可以添加抽象方法
*/
abstract class Animal{
name : string
constructor(name:string){
this.name = name
}
// 定义一个抽象方法
/*
抽象方法使用abstract开头,没有方法体
抽象方法只能定义在抽象类中,子类必须对抽象方法进行重写
*/
abstract sayHello():void
}
class Dog extends Animal{
sayHello(){
console.log('汪汪汪')
}
}
class Cat extends Animal{
sayHello(){
console.log('喵喵喵')
}
}
接口 interface
接口定义
/*
接口用来定义一个类结构
同时接口也可以当成类型声明去使用
*/
// 定义一个接口,并声明属性
interface myInterface{
name: string
age: number
}
const obj: myInterface = {
name: 'sss',
age: 111
}
console.log(obj) //{ name: 'sss', age: 111 }
// 再次定义接口,并新增属性,此时接口中有三个属性
interface myInterface{
gender: string
}
const obj: myInterface = {
name: 'sss',
age: 111,
gender: '男'
}
console.log(obj) // { name: 'sss', age: 111, gender: '男' }
接口属性
/*
接口可以在定义类是去限制类的结构
接口中的所有的属性都不能有实际的值
接口只定义对象的结构,而不考虑实际的值
在接口中所有的方法都是抽象方法
*/
interface myInter{
name: string
sayHello():void
}
接口就是定义一个规范,是对类的限制
/*
定义类时,可以使用类去实现一个接口
实现接口就是让类满足接口的要求
*/
// 接口就是定义一个规范,是对类的限制
class MyClass implements myInter{
name: string
constructor(name:string){
this.name = name
}
sayHello(){
console.log('大家好~~~')
}
}
属性的封装
/*
ts可以在属性前添加属性的修饰符
public 修饰的属性可以在任意位置访问,修改, 默认值
private 私有属性,私有属性只能在类内部进行访问,修改
通过在类中添加方法使得私有属性可以被外部访问
*/
class Person{
private _name:string;
private _age: number
constructor(name:string, age:number){
this._name = name
this._age = age
}
// 定义方法,用来获取私有name属性
getName(){
return this._name
}
// 定义方法,用来设置私有name属性
setName(value:string){
this._name = value
}
}
const per = new Person('孙悟空', 18)
console.log(per.getName()) //孙悟空
per.setName('123')
console.log(per.getName()) //123
get与set方法
/*
ts可以在属性前添加属性的修饰符
public 修饰的属性可以在任意位置访问,修改, 默认值
private 私有属性,私有属性只能在类内部进行访问,修改
通过在类中添加方法使得私有属性可以被外部访问
*/
class Person{
private _name:string;
private _age: number
constructor(name:string, age:number){
this._name = name
this._age = age
}
// 在ts中设置getter方法的方式
get name(){
return this._name
}
// set方法
set name(value){
this._name = value
}
}
const per = new Person('孙悟空', 18)
console.log(per.name) // 孙悟空
// 调用get方法
per.name = '猪八戒'
console.log(per.name) //猪八戒
proted
/*
protected 受保护的属性,只能在当前类和当前类的子类中访问,修改
*/
class A{
protected num: number
constructor(num:number){
this.num = num
}
}
class B extends A{
test(){
console.log(this.num)
}
}
直接将函数定义在构造函数中
class C{
// 可以直接将属性定义在构造函数中
constructor(public name:string, public age:number){
}
}
const c = new C('xxx', 111)
console.log(c) // C { name: 'xxx', age: 111 }
等价于
class C{
constructor(name:string, age:number){
this.name = name
this.age = age
}
}
泛型
/*
在定义函数或是类时,如果遇到类型不明确就可以使用泛型
泛型指不确定的类型
*/
function fn<T>(a: T):T{
return a
}
// 可以直接調用具有范型的函数
let result = fn(10) // 不指定泛型,TS可以自动对类型进行判断
let result2 = fn<string>('hello') // 指定泛型
// 泛型可以同时指定多个
function fn2<T, K>(a: T,b: K):T{
console.log(b)
return a
}
fn2<number, string>(123, 'hello')
interface Inter{
legth: number
}
//
function fn3<T extends Inter>(a: T): number{
return a.length;
}
class MyClass<T>{
name: T;
constructor(name: T){
this.name = name
}
}
const mc = new MyClass<string>("will")
Typescript:基础语法学习(尚硅谷 李立超)的更多相关文章
- Swift基础语法学习总结(转)
Swift基础语法学习总结 1.基础 1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift使用print和println打印,它的传参是一个泛型 ...
- Swift基础语法学习总结
Swift基础语法学习总结Swift高级语法学习总结Swift语法总结补充(一) 1.基础 1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift ...
- Python 基础语法学习(第一讲)---类的使用
[写在前面]:其实自学python有一段时间了,但是一直没想起来要写博客来记录自己的学习,今天才感觉要写点什么让自己学的更扎实一点,所以从今天开始更新python自学系列,希望看见文章的大佬们可以指点 ...
- Java基础语法学习
Java基础语法学习 1. 注释 单行注释: //单行注释 多行注释: /*多行注释 多行注释 多行注释 多行注释 */ 2. 关键字与标识符 关键字: Java所有的组成部分都需要名字.类名.变量名 ...
- C++基础语法学习:STL
基础语法学习,少点比较,多些谦虚 1.容器: 常见的容器有以下几类: 1.vector:向量 2.deque:双端队列 3.list:列表 4.set:集合 5:multiset:多重集合 6.map ...
- 2020寒假学习笔记14------Python基础语法学习(三)
今天学习了Python的基础语法,其中学的内容有: 比较运算符.逻辑运算符.同一运算符.整数缓存问题.基本运算符.复合复制运算符.运算符优先级问题.字符串基本特点.字符串的编码.空字符串和len()函 ...
- java 基础语法学习01
Java基础语法 注释 初次使用idea时相关配置 new project ->Empty project->进入页面 再选择file->project structure-> ...
- Docker基础学习-尚硅谷
视频地址:链接: https://pan.baidu.com/s/15sJuEh5cVTJ7-vWSH7vffw 提取码: zf25 笔记:
- React基础语法学习
React主要有如下3个特点: 作为UI(Just the UI) 虚拟DOM(Virtual DOM):这是亮点 是React最重要的一个特性 放进内存 最小更新的视图,差异部分更新 diff算法 ...
- typescript基础类型(学习笔记非干货)
布尔值 Boolean let isDone:boolean=false; 数字 Number let decLiteral:number=6; let hexLiteral:number=0xf00 ...
随机推荐
- [C++核心编程] 4.6、继承
文章目录 4.6 继承 4.6.1 继承的基本语法 4.6.2 继承方式 4.6.3 继承中的对象模型 4.6.4 继承中构造和析构顺序 4.6.5 继承同名成员处理方式 4.6.6 继承同名静态成员 ...
- Centos7安装JDK1.8详细步骤
JDK 解压JDK安装文件.在终端中,进入你下载的JDK安装文件所在的目录,然后执行以下命令: tar -zxvf jdk-<版本号>-linux-x64.tar.gz 其中,<版本 ...
- Python定时任务框架apscheduler的简单使用
apscheduler的简单使用 APScheduler有四大组件: 1.触发器 triggers : 触发器包含调度逻辑.每个作业都有自己的触发器,用于确定下一个任务何时运行.除了初始配置之外,触发 ...
- 用tk.mybaits实现指定字段更新
去年年底的因为业务需要需要在使用tk.mybaits框架的系统中实现指定字段的更新,可是tk.mybaits框架本身并不支持这个功能,我翻遍了CSDN和其他相关的技术相关的网站都没有找到相关的解决 ...
- 2022-06-16:给定一个数组arr,含有n个数字,都是非负数, 给定一个正数k, 返回所有子序列中,累加和最小的前k个子序列累加和。 假设K不大,怎么算最快? 来自亚马逊。
2022-06-16:给定一个数组arr,含有n个数字,都是非负数, 给定一个正数k, 返回所有子序列中,累加和最小的前k个子序列累加和. 假设K不大,怎么算最快? 来自亚马逊. 答案2022-06- ...
- 2021-01-07:cdn加速是什么原理?
福哥答案2021-01-07:[答案来自此链接:](https://www.zhihu.com/question/438234873)CDN(Content Delivery Network):内容分 ...
- 【工作随手记】deaklock排查
生产环境当中还没真正遇到过死锁的问题.有些疑似死锁的问题,后来经过排查也只是其它问题导致的.所以通过jstack到底怎样排查死锁问题有点疏忽了.这里作个记录. 模拟一个死锁 顺便复习一下. 死锁的产生 ...
- 虚拟机linux系统密码忘记了该怎么办?
当你的linux系统的密码忘记了该怎么办? 首先不要慌,重启电脑,开机的时候 出现这个页面的时候点击e然后出现这个页面 把里面的ro修改为 rw 修改为rw之后在这一行语句的最后面输入enforcin ...
- vue-router几大坑
如今vue使用率很高,踩坑这就是很平常的了,使用了几年坑都依然没踩完,纠结呀 一.router.js配置要点 大家都知道vue 是组件化开发,页面很多路由难免, 这里是路由配置router.js 最外 ...
- 用 Python + turtle 模块绘制五星红旗
用 Python 绘制五星红旗 在这个代码示例中,我将介绍如何使用 Python 的 turtle 模块绘制五星红旗.turtle 模块是一个图形库,可以轻松地在 Python 中实现简单的绘图功能. ...