typescript2-类的类型

/*

  • 输出

  • 吃饭

  • 游泳

*/




[]( )继承与多态

------------------------------------------------------------------------



1.  子类继承父类特征子类 extends 父类

2.  当需要父类参数传递时,用子类也可以,这就是多态



/*

  • 继承:子类继承父类

  • 多态:当需要父类参数时,传入子类的也可以

  • */

class Animal{

name: string

constructor(name:string) {

    this.name=name

}

run(distance=0){

    console.log(this.name+"跑了" + distance + "米")

}

}

class Dog extends Animal{

constructor(name:string="dog") {

    super(name);

}

run(distance=5){

    console.log(this.name+"跑了" + distance + "米")

}

}

class Cat extends Animal{

constructor(name:string="cat") {

    super(name);

}

run(distance=10){

    console.log(this.name+"跑了" + distance + "米")

}

}

const animal1=new Animal(“aniaml”)

animal1.run()

const dog1=new Dog()

dog1.run()

const cat1=new Cat()

cat1.run()

const dog2:Animal=new Dog() // 当使用了父元素类型Animal也没报错,这就是因为多态

dog2.run()

/*

  • 输出

  • aniaml跑了0米

  • dog跑了5米

  • cat跑了10米

  • dog跑了5米

*/




[]( )类的修饰符

------------------------------------------------------------------------



1.  修饰构造函数,属性,方法是否可以被外部访问



| 修饰符 | 作用范围 |

| :-: | :-: |

| public | 公共的,默认属性,都可以访问 |

| protected | 外部无法访问,子类可以访问 |

| private | 内部使用,外部无法访问,子类也无法访问 |

| readonly | 只读属性,添加后外部就不能修改了,只能在构造函数内修改 |



class Person{

readonly name: string

constructor(name: string) {

    this.name=name

}

showName(){

	//在类中的普通方法中也不能对只读属性的name重新赋值

    // this.name="rose"

    console.log(this.name)

}

}

//实例化对象

const p1: Person=new Person(“jack”)

p1.showName()

//输出jack

// p1.name=“rose”

/*

  • 这里应为实在类的外部,name为只读的,所以不能再对name赋值

*/




3.  参数属性



*   构造函数中的参数如果使用readonly修饰后,那么参数就叫参数属性

*   构造函数中的参数如果使用readonly修饰后,那么类中就有了一个参数成员

*   构造函数中的参数如果使用readonly修饰后,外部也是无法访问的

*   构造函数中的参数如果使用其他修饰后,那么类中就有了一个相应作用范围的参数成员



class Person{

//虽然类中并没name属性,但这里使用了readonly属性修饰,在类中隐式添加了一个name属性

constructor(readonly name: string='jack') {

    this.name=name

}

showName(){

    console.log(this.name)

}

}

//实例化对象

const p1: Person=new Person()

p1.showName()




[]( )存取器

----------------------------------------------------------------------



TypeScript 支持通过 getters/setters 来截取对对象成员的访问,它能帮助你有效的控制对对象成员的访问



class Person{

private firstName: string

private lastName: string

constructor(firstName,lastName) {

    this.firstName = firstName

    this.lastName = lastName

}

get fullName(){

    return this.firstName+ "-" + this.lastName

}

set fullName(value){

    let val = value.split("-")

    this.firstName = val[0]

    this.lastName = val[1]

}

}

const p1: Person=new Person(“东方”,“不败”)

console.log(p1.fullName)

p1.fullName = “西门-吹雪”

console.log(p1.fullName)

/*

  • 输出

  • 东方-不败

  • 西门- 吹雪

Vue 面试题

1.Vue 双向绑定原理
2.描述下 vue 从初始化页面–修改数据–刷新页面 UI 的过程?
3.你是如何理解 Vue 的响应式系统的?
4.虚拟 DOM 实现原理
5.既然 Vue 通过数据劫持可以精准探测数据变化,为什么还需要虚拟 DOM 进行 diff 检测差异?
6.Vue 中 key 值的作用?
7.Vue 的生命周期
8.Vue 组件间通信有哪些方式?
9.watch、methods 和 computed 的区别?
10.vue 中怎么重置 data?
11.组件中写 name 选项有什么作用?
12.vue-router 有哪些钩子函数?
13.route 和 router 的区别是什么?
14.说一下 Vue 和 React 的认识,做一个简单的对比
15.Vue 的 nextTick 的原理是什么?
16.Vuex 有哪几种属性?
17.vue 首屏加载优化
18.Vue 3.0 有没有过了解?
19.vue-cli 替我们做了哪些工作?

的生命周期
8.Vue 组件间通信有哪些方式?
9.watch、methods 和 computed 的区别?
10.vue 中怎么重置 data?
11.组件中写 name 选项有什么作用?
12.vue-router 有哪些钩子函数?
13.route 和 router 的区别是什么?
14.说一下 Vue 和 React 的认识,做一个简单的对比
15.Vue 的 nextTick 的原理是什么?
16.Vuex 有哪几种属性?
17.vue 首屏加载优化
18.Vue 3.0 有没有过了解?
19.vue-cli 替我们做了哪些工作?
[外链图片转存中…(img-zkYVZ2gN-1720101823341)]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/771592.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

集团型企业组织架构复杂,业务线多,如何进行高效费用管控?

企业管理中流行这样一句话:“企业转型,财务先行”。对集团型企业而言,当今的发展形势下,通过财务战略全面转型、最终撬动企业价值提升,是一件难而正确的事情。 集团企业具有经营规模大、产业链多、分支机构多、地域跨度…

容器部署rabbitmq集群迁移

1、场景: 因业务需要,要求把rabbitmq-A集群上的数据迁移到rabbitmq-B集群上,rabbitmq的数据包括元数据(RabbitMQ用户、vhost、队列、交换和绑定)和消息数据,而消息数据存储在单独的消息存储库中。 2、迁移要…

中国算力网络市场发展分析

中国算力网络市场发展现状 算力涵盖计算、内存、存储等全方位能力,广泛分布于网络边缘、云计算中心、联网设备及转发节点。随着数字化技术革新,算力与网络正深度融合,推动“算网一体化”的演进。这一新型基础设施日渐凸显其重要性&#xff0c…

番外篇 | YOLOv8改进之即插即用全维度动态卷积ODConv + 更换Neck网络为GFPN

前言:Hello大家好,我是小哥谈。本文所做出的改进是在YOLOv8中引入即插即用全维度动态卷积ODConv和更换Neck网络为GFPN,希望大家学习之后能够有所收获~!🌈 目录 🚀1.基础概念 🚀2.网络结构 🚀3.添加步骤 🚀4.改进方法 🍀🍀步骤1:block.py文件修改…

Kamailio-Web管理页面Siremis的安装与部署

siremis 是针对于 Kamailio 的web管理接口,使用PHP书写,更新至2020年,相对不是太新但是是官方友链的 以下就采用 Ubuntu 22.04Siremis 5.8.0apache http server 2.4php7.0 如有疑问请参看官方指南 以下开始介绍操作步骤 安装apache2.4 we…

一文读懂什么是“GPU算力”

在数字化转型的浪潮中,各行业对算力的需求日益激增,GPU(图形处理单元)算力作为推动科技进步的重要力量,正逐步从传统的图形渲染领域扩展到人工智能、大数据分析、高性能计算等多个前沿领域。通过本文,深入剖…

亮相2024世界人工智能大会,扫描全能王AIGC“黑科技”助力敦煌遗书数字化修复

7月4日,2024年世界人工智能大会(简称“大会”)在上海举行。这次这场科技与创新的盛会上,一张古朴、典雅的卷轴吸引了众人的目光。这张被修复的卷轴脱胎于敦煌遗书系列古籍,在被机器拍摄扫描后,卷轴上脏污、…

Airflow: 大数据调度工具详解

欢迎来到我的博客,很高兴能够在这里和您见面!欢迎订阅相关专栏: 欢迎关注微信公众号:野老杂谈 ⭐️ 全网最全IT互联网公司面试宝典:收集整理全网各大IT互联网公司技术、项目、HR面试真题. ⭐️ AIGC时代的创新与未来&a…

SalesForce集成案例-获取联系人信息

SalesForce本身比较复杂,涉及的东西比较多,下面以使用REST API接口为例,介绍与SalesForce集成的过程,集成案例:获取联系人信息。 首先需要注册一个免费的开发者帐号,具有完全操作SalesForce的权限。 1、注…

Echarts中的热力图和漏斗图(在Vue中使用热力图和漏斗图)

热力图 (Heatmap) Echarts的热力图用于展示两个维度数据矩阵中的值分布情况。它通过在平面上划分成多个矩形区域,并用不同的颜色填充这些区域来表示数据的大小或强度。颜色渐变从浅到深通常映射着数值从小到大,从而直观展示数据的集中程度和分布模式。热…

STM32工业自动化控制系统教程

目录 引言环境准备工业自动化控制系统基础代码实现:实现工业自动化控制系统 4.1 数据采集模块 4.2 数据处理与分析 4.3 控制系统实现 4.4 用户界面与数据可视化应用场景:工业自动化与优化问题解决方案与优化收尾与总结 1. 引言 工业自动化控制系统利用…

INFINI Console 使用介绍

上次在《INFINI Easysearch尝鲜Hands on》中我们部署了两个节点的Easysearch,并且也设置了Console对集群进行监控。那么今天我们再来介绍下INFINI Console的使用。 INFINI Console 仪表盘功能介绍 INFINI Console 是一个功能强大的数据管理和分析平台,…

JBoss JMXInvokerServlet 反序列化漏洞

漏洞原理: 这是经典的JBoss反序列化漏洞,JBoss在/invoker/JMXInvokerServlet请求中读取了用户传入的对象,然后我们利用Apache Commons Collections中的Gadget执行任意代码。 影响版本: JBoss Enterprise Application Platform 6…

实时数仓Hologres OLAP场景核心能力介绍

作者:赵红梅 Hologres PD OLAP典型应用场景与痛点 首先介绍典型的OLAP场景以及在这些场景上的核心痛点,OLAP典型应用场景很多,总结有四类:第一类是BI报表分析类,例如BI报表,实时大屏,数据中台等…

Java项目:基于SSM框架实现的班主任助理管理系统【ssm+B/S架构+源码+数据库+开题报告+毕业论文】

一、项目简介 本项目是一套基于SSM框架实现的班主任助理管理系统 包含:项目源码、数据库脚本等,该项目附带全部源码可作为毕设使用。 项目都经过严格调试,eclipse或者idea 确保可以运行! 该系统功能完善、界面美观、操作简单、功…

iOS App 测试环境升级,遇到的问题以及解决方法

iOS App 测试环境升级,遇到的问题以及解决方法 Mac 实体机升级到 Sonima 14.5 Xcode 升级到 15.3 问题1: Xcode 编译 WebDriverAgent 失败 尝试下载 最新版本的WDA 源码编译,可以编译成功。 问题2:具体坐标直接点击的代码都会报错…

【UML用户指南】-28-对体系结构建模-部署

目录 1、名称 2、节点与制品 2.1、结点与制品相同: 2.2、不同 3、组织结点 4、连接 5、常用建模技术 5.1、对处理器和设备建模 5.2、对制品的分布建模 正如制品一样,结点存在于物质世界中,在对系统的物理方面建模中它是一个重要构造…

关键词感知检索

背景介绍 关键词检索及其局限 在信息检索领域,“传统”方式是通过关键词进行信息检索,其大致过程为: 对原始语料(如网页)进行关键词抽取。 建立关键词和原始语料的映射关系,常见的方法有倒排索引、TF-ID…

Spring源码十:BeanPostProcess

上一篇Spring源码九:BeanFactoryPostProcessor,我们看到ApplicationContext容器通过refresh方法中的postProcessBeanFactory方法和BeanFactoryPostProcessor类提供预留扩展点,他可以在Spring容器的层面对BeanFactroy或其他属性进行修改&#…

Python图书信息管理系统(完整代码)

引言:(假装也不是一个大学生课设)在数字化和信息化快速发展的今天,图书管理系统成为了图书馆、学校及个人图书收藏管理中不可或缺的工具。这类系统不仅能有效地管理大量的图书资料,还能提高图书检索、借阅和归还的效率…