day22|学习前端ts语言

抽象类,继承。不能创造实例

class类:属性声明,构造器,方法,实例

继承super()

override重写父类继承的方法

声明提升(hoisting)同一个js作用域内部,编译阶段把函数声明提前到作用域顶部

区分两者:

函数提前可用是作用域编译阶段的行为(声明提升)

跨文化提前可用是模块加载顺序的行为(依赖先执行)

类不会声明提升

属性的简写形式

属性修饰符:public,protected,private,readonly只读属性

抽象类abstract,不能被new。不能用new关键词直接创建(实例化)这个类的对象

主要用于继承

函数名(参数列表){

函数体

何时使用抽象类:定义通用接口,提供基础实现,共享代码逻辑

interface接口:定义结构的方式

implement定义类

定义对象结构、函数结构

ts的接口可以当成类型用

接口之间的继承

接口自动合并(可重复定义)

何时用接口?定义对象的格式(描述数据模型,API响应格式,配置对象);类的契约;扩展已有接口

interface和抽象类区别

都能定义类的格式

接口:只能描述结构,不能有任何实现代码,一个类可以实现多个接口

抽象类:可以包含抽象方法,也可以包含具体方法。一个类只能继承一个抽象类

泛型< T >使用类型参数来表示未指定的类型

泛型函数

泛型可以有多个,泛型接口extraInfo

类型声明文件

.d.ts作为拓展名

相关推荐
Lsx_几秒前
分不清RAG 、Function Call、MCP、Agent?一文秒懂它们的区别和联系
前端·agent·mcp
毕了业就退休21 分钟前
websocket 的心跳机制你知道几种
前端·javascript·http
子林super22 分钟前
aiforcast集群单节点CPU使用率100%问题
前端
CF14年老兵24 分钟前
为什么 position: absolute 在 Flexbox 里会失效?
前端·css·trae
xianxin_28 分钟前
CSS 选择器
前端
徐小夕29 分钟前
花3个月时间,写了一款协同文档编辑器
前端·vue.js·算法
Nicholas6836 分钟前
flutter滚动视图之ScrollDirection、ViewportOffset源码解析(一)
前端
Dream耀1 小时前
FitKick 电商APP项目总结二
前端·javascript·react.js
ZsTs1191 小时前
一篇通关:从 MVVM 到渲染优化,Vue 基础核心 5 大模块全解析
前端·vue.js·面试
石小石Orz1 小时前
视差悬停特效:鼠标跟随的沉浸式交互体验
前端·css·trae