JavaScript 进阶--charater3

news2024/9/28 7:23:17

文章目录

  • 前言
  • 一、编程思想
    • 1.1 面向过程介绍
    • 1.2 面向对象编程 (oop)
    • 对比
  • 二、构造函数
  • 三、原型
    • 3.1原型
    • 3.2 constructor 属性
    • 3.3 对象原型
    • 3.4 原型继承
    • 3.5 原型链
  • 总结


前言

🆑学习目标

  1. 理解面向对象思想,掌握函数原型对象
  2. 运用面向对象封装继承特点,封装确认框对话功能。

一、编程思想

1.1 面向过程介绍

面向过程就是分析出解决问题所需要的步骤,然后用函数把这些步骤一步一步实现,使用的 时候再一个一个的依次调用即可。
就是按照我们分析好步骤,按照步骤解决问题

1.2 面向对象编程 (oop)

面向对象是把事务分解成一个个对象,然后由对象之间分工与合作。
面向对象就是以对象功能来划分问题,而不是步骤。

  • 面向对象程序开发思想中,每个对象都是功能中心,具有明确分工。
  • 面向对象编程具有灵活,代码可复用,容易维护,和开发的优点,更合适多人合作的大型软件项目。

面向对象的特性:
封装性
继承性
多态性

对比

⭕️面向过程编程

优点:性能比面向对象高,适合跟硬件联系很紧密的东西。例如单片机采用的面向过程编程。
缺点:没有面向对象以维护,易复用,易扩展。

面向对象编程

优点:易维护,易复用,由于面向对象由封装,继承,多态的特性。可以设计出低耦合的系统,使系统更加灵活,更加易维护。
缺点:性能比面向过程低。

二、构造函数

  • 封装使面向对象思想中比较重要的一部分,js面向对象可以通过构造函数实现的封装。
  • 同样的将变量函数组合到一起并通过this实现数据的共享,所不同的使借助构造函数创建出来的实例对象之间是彼此不影响的。
// 构造函数  公共的属性和方法 封装到 Star 构造函数里面了
    // 1.公共的属性写到 构造函数里面
    function Star(uname, age) {
      this.uname = uname
      this.age = age
      this.sing = function () {
        console.log('唱歌')
      }
    }
    const ldh = new Star('刘德华', 55)
    const zxy = new Star('张学友', 58)
    ldh.sing() //调用
    zxy.sing() //调用

在这里插入图片描述
前面我们学过的构造函数方法很好用,但是存在浪费内存的问题。

 console.log(ldh === zxy)  // false
 console.log(ldh.sing === zxy.sing) // true

三、原型

3.1原型

目标:能够利用原型对象实现方法共享

  • 构造函数通过原型分配的函数是所有对象所共享的
  • Javascript 规定,每一个构造函数都有一个prototype 属性,指向一个对象,所有也称为原型对象。
  • 这个对象可以挂载函数,对象实例化不会多次创建原型上函数,节约内存。
  • 把不变的方法,直接定义在prototype对象上,这样所有对象的实例化就可以共享这些方法`。
    在这里插入图片描述
    代码如下(示例):
Function Star(uname,age)
  this,uname=uname
  this,age=age
console.log(Star.prototype)//返回一个对象称为原型对象
Star.prototype.sing function (){
  console.1og("我会唱歌)
}
const 1dh=new Star('刘德华'18)
const zxy=new5tar('张学友'19)
console.1og(ldh.sing == zxy.sing)
//结果是true说明俩函数一样,共享

3.2 constructor 属性

每一个原型对象都有一个constructor 属性 (constructor 构造函数

使用场景:如果有多个对象的方法,我们可以给原型对象采取对象形式赋值。但是这样会覆盖构造函数原型对象原来的内容。

function star(name){
	this.name=name
}
star.prototype = {
	//手动利用construtor 指向 star
	construtor : star// 如果不指向 就会默认指向object	
	console.log(star.prototype.constructor)//指向 object
	sing : function()console.log("sing"),
	dance : function()console.log("dance")
}
console.log(star.prototype.constructor)//指向原型对象star

3.3 对象原型

🔥 思考
构造函数可以创建实例对象,构造函数还有一个原型对象,一些公共的属性或方法放到这个原型对象可以共享属性和方法?
:对象都会有一个属性_proto_ 指向构造函数的 prototype原型对象 ,因为对象有_proto_ 原型的存在。
在这里插入图片描述

 function Star() {
    }
    const ldh = new Star()
    // 对象原型__proto__ 指向 改构造函数的原型对象
    console.log(ldh.__proto__) // object
     console.log(ldh.__proto__ === Star.prototype) // true
    // 对象原型里面有constructor 指向 构造函数 Star
    console.log(ldh.__proto__.constructor === Star) // true

❌注意

  1. _proto _ 是JS非标准属性
  2. [{prototype}] 和 proto 意义相同
  3. 用来表明当前实例对象指向哪个原型对象prototype
  4. proto 对象原型里面有一个constructor属性,指向创建该实例对象的构造函数

在这里插入图片描述

3.4 原型继承

通过继承进一步提升代码封装的程度,JavaScript大多是借助原型对象实现继承的特性。

    function Man(){
        this.head =1;
        this.eyes =2;
        this.legs =2;
        this.say =function (){}
        this.eat= function (){}
    } 
    const pink= new Man()
    console.log(pink)// Man 对象

封装–抽取公共部分

  1. 让男人和女人都能继承人类的一些属性和方
  2. 把男人女人公共的属性和方法抽取出来 People
  3. 然后赋值给Man的原型对象,可以共享这些属性和方法
  4. 注意让constructor指回Man这个构造函数
     //人类
    const People ={
      head:1,
      eyes:2,
      legs:2,
      say:function (){},
      eat:function (){}
    }
    //男人
    function Man(){
    }
    // 把公共的属性和方法给原型,这样就可以共享
    Man.prototype = People
    //让原型里面的constructor 从新指向Man找父级
    Man.prototype.constructor=Man
    const pink = new Man()
    console.log(pink) 

在这里插入图片描述
男人和女人都同时使用了同一个对象,根据引用类型的特点,他们指向同一个对象,修改一个就会都影响。
在这里插入图片描述
如果男人添加吸烟的方法,女人的对象原型也会添加。

Man.prototype.smoking= function(){}

在这里插入图片描述
完善继承写法,即消除原型对象指向同一个固定对象。

function Man(){}
Man.prototype = new Person()
// 让原型里面的constructor 从新指向找自己的父级
Man.prototype.constructor = Man
Man.prototype.smoking = function(){}
console.log(Man)

3.5 原型链

基于原型对象的继承使得不同构造函数的原型对象关联在一起,并且这个关联的关系是一种链状的结构,我们将原型对象的链状结构关系称为原型链

🌭查找规则

  1. 当访问一个对象的属性包括方法时,首先查找这个对象自身有没有该属性。
  2. 如果没有就查找它的原型,即_proto_ 指向的 prototype 原型对象
  3. 如果还没有就查找原型对象的原型,即Object对象
  4. 一次类推一直找到Object 为止
  5. _ proto_ 对象原型的意义就只在于为对象成员查找机制提供一个方向,或者说一条路线。

总结

这章理解面向对象思路,并且掌握函数原型对象,
会用面向对象封装继承特点,实现封装方法的使用。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

腾讯开源的 hel 提供了加载远程模块的能力,谈谈它的实现原理

腾讯开源的 hel,提供了一种运行时引入远程模块的能力,模块部署在 CDN,远程模块发布后,不需要重新构建发布,就能生效。 个人觉得它的实现原理非常的不错,因此分享给大家。 远程模块可以作为微模块&#xf…

Jenkins利用docker部署vue项目

Jenkins利用docker部署vue项目一、环境准备1、安装docker2、安装nodejs3、安装cnpm与配置淘宝镜像4、jenkins安装nodejs插件二、jenkins以vue项目1、全局参数配置2、源码配置3、构建环境4、构建三、构建项目四、访问一、环境准备 本次jenkins与部署vue项目在同一台机器&#x…

RocketMQ5.0.0的Broker主从同步机制

目录 一、主从同步工作原理 1. 主从配置 2. 启动HA 二、主从同步实现机制 1. 从Broker发送连接事件 2. 主Broker接收连接事件 3. 从Broker反馈复制进度 4. ReadSocketService线程读取从Broker复制进度 5. WriteSocketService传输同步消息 6. GroupTransferService线程…

【每日一题Day127】LC1238循环码排列 | 格雷码构造 位运算

格雷码 看到题目就想到了格雷码 然后就疯狂搜索格雷码 手动构造了一波格雷码 看了题解 emmm 有点亏 理论基础 n 位格雷码序列 是一个由 2n 个整数组成的序列,其中: 每个整数都在范围 [0, 2n - 1] 内(含 0 和 2n - 1)第一个整数是…

深度学习之“制作自定义数据”--torch.utils.data.DataLoader重写构造方法。

深度学习之“制作自定义数据”–torch.utils.data.DataLoader重写构造方法。 前言: ​ 本文讲述重写torch.utils.data.DataLoader类的构造方法,对自定义图片制作类似MNIST数据集格式(image, label),用于自己的Pytorc…

大数据Hadoop教程-学习笔记04【数据仓库基础与Apache Hive入门】

视频教程:哔哩哔哩网站:黑马大数据Hadoop入门视频教程 总时长:14:22:04教程资源: https://pan.baidu.com/s/1WYgyI3KgbzKzFD639lA-_g 提取码: 6666【P001-P017】大数据Hadoop教程-学习笔记01【大数据导论与Linux基础】【17p】【P018-P037】大…

Spring boot开启定时任务的三种方式(内含源代码+sql文件)

Spring boot开启定时任务的三种方式(内含源代码sql文件) 源代码sql文件下载链接地址:https://download.csdn.net/download/weixin_46411355/87486580 目录Spring boot开启定时任务的三种方式(内含源代码sql文件)源代码…

【无人机】回波状态网络(ESN)在固定翼无人机非线性控制中的应用(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

前端常见手写面试题集锦

实现迭代器生成函数 我们说迭代器对象全凭迭代器生成函数帮我们生成。在ES6中,实现一个迭代器生成函数并不是什么难事儿,因为ES6早帮我们考虑好了全套的解决方案,内置了贴心的 生成器 (Generator)供我们使用&#xff…

java面试题-IO流

基础IO1.如何从数据传输方式理解IO流?IO流根据处理数据的类型可以分为字节流和字符流。字节流字节流以字节(8位)为单位读写数据。字节流主要用于读写二进制文件,如图片、音频、视频等。Java中的InputStream和OutputStream就是字节…

写论文不用构建语料库!只需要福昕PDF阅读器高级搜索

写论文不用构建语料库!只需要福昕PDF阅读器高级搜索 文章目录写论文不用构建语料库!只需要福昕PDF阅读器高级搜索前言:“福昕语料库”使用前的准备:调用“语料库”:前言: 最近论文阅读可以借助NewBing的总…

【算法与数据结构(C语言)】栈和队列

文章目录 目录 前言 一、栈 1.栈的概念及结构 2.栈的实现 入栈 出栈 获取栈顶元素 获取栈中有效元素个数 检测栈是否为空,如果为空返回非零结果,如果不为空返回0 销毁栈 二、队列 1.队列的概念及结构 2.队列的实现 初始化队列 队尾入队列 队头出队列 获…

报表开发难上手?这里有一份 Fastreport 最新中文用户指南,请查收

Fast Reports,Inc.成立于1998年,多年来一直致力于开发快速报表软件,包括应用程序、库和插件。FastReport的报表生成器(VCL平台和.NET平台)、跨平台的多语言脚本引擎FastScript、桌面OLAP FastCube,如今都受到世界各地开…

Typecho COS插件实现网站静态资源存储到COS,降低本地存储负载

Typecho 简介Typecho 是一个简单、强大的轻量级开源博客平台,用于建立个人独立博客。它具有高效的性能,支持多种文件格式,并具有对设备的响应式适配功能。Typecho 相对于其他 CMS 还有一些特殊优势:包括可扩展性、不同数据库之间的…

IDA 实战--(2)熟悉工具

布局介绍 软件启动后会 有几个选项,一般直接选择Go 即可 之后的工作台布局如下 开始分析 分析的第一个,将PE 文件拖入工作区 刚开始接触,我们先保持默认选项,其它选项后面会详细讲解,点击OK 后,等待分析…

软件项目管理知识回顾---软件项目质量和资源管理

软件项目质量和资源管理 5.0质量管理 5.1质量管理模型 1.模型 boehm模型:可移植性,可使用性,可维护性McCall模型ISO体系认证5.2质量成本 1.含义:由于产品第一次不正常运行而产生的附加费用 预防成本和缺陷成本5.3质量管理 1.过程 …

Python opencv进行矩形识别

Python opencv进行矩形识别 图像识别中,圆形和矩形识别是最常用的两种,上一篇讲解了圆形识别,本例讲解矩形识别,最后的结果是可以识别出圆心,4个顶点,如下图: 左边是原始图像,右边是识别结果,在我i5 10400的CPU上,执行时间不到8ms。 识别出结果后,计算任意3个顶点…

【自监督论文阅读笔记】Unsupervised Learning of Dense Visual Representations

Abstract 对比自监督学习已成为无监督视觉表示学习的一种有前途的方法。通常,这些方法学习全局(图像级)表示,这些表示对于同一图像的不同视图(即数据增强的组合)是不变的。然而,许多视觉理解任务…

PDF文件怎么转图片格式?转换有技巧

PDF文件有时为了更美观或者更直观的展现出效果,我们会把它转成图片格式,这样不论是归档总结还是存储起来都会更为高效。有没有合适的转换方法呢?这就来给你们罗列几种我个人用过体验还算不错的方式,大家可以拿来参考一下哈。1.用电…

vm 网络配置

点击NAT设置,配置本台虚拟机ip(注意网关要在同一个网段),配置对应端口 然后添加映射端口: 然后选择网络适配器 选择vm8网卡 配置网卡静态ip #查看网卡 ip addr #修改网卡配置 cd /etc/sysconfig/network-scripts…