【JavaScript】理解面向对象以及构造函数的推导

news2025/1/11 2:53:55

💻 【JavaScript】理解面向对象以及构造函数的推导 🏠专栏:JavaScript
👀个人主页:繁星学编程🍁
🧑个人简介:一个不断提高自我的平凡人🚀
🔊分享方向:目前主攻前端,其他知识也会阶段性分享🍀
👊格言:☀️没有走不通的路,只有不敢走的人!☀️
👉让我们一起进步,一起成为更好的自己!!!🎁

文章目录

  • JavaScript 理解面向对象以及构造函数的推导
    • 一. 面向对象和面向过程
      • (1) 面向过程的基本概念
      • (2) 面向对象的基本概念
    • 二. 面向对象和面向过程的区别
    • 三. 构造函数的推导
    • 四. 构造函数
      • (1) 概念
      • (2) 构造函数特点总结
      • (3) 构造函数案例

JavaScript 理解面向对象以及构造函数的推导

一. 面向对象和面向过程

(1) 面向过程的基本概念

面向过程(Procedure Oriented)是一种以过程为中心的编程思想。

面向过程就是分析出解决问题所需要的步骤,然后用函数把这些步骤一步一步实现,使用的时候一个一个依次调用就可以了。是一种思考问题的基础方法。

简单理解:面向过程就是任何事情都亲力亲为,很机械,像个步兵。

(2) 面向对象的基本概念

面向对象(Object Oriented)是软件开发方法中的一种;是一种对现实世界理解和抽象的方法;是思考问题相对高级的方法。

面向对象是把构成问题事务分解成各个对象,建立对象的目的不是为了完成一个步骤,而是为了描叙某个事物在整个解决问题的步骤中的行为。

简单理解:面向对象就像战场上的指挥官,指挥战斗而不必知道具体执行的过程。

:面向对象:对象来自于类,必须先有类在有对象,类在js中也叫构造函数。

面向对象和面向过程的联系:面向对象就是面向过程的封装。

二. 面向对象和面向过程的区别

  1. 面向对象是相对面向过程而言的,面向对象包含了面向过程的思想。
  2. 面向过程就是分析出解决问题所需要的步骤,关注的是解决问题需要那些步骤。
  3. 面向对象是把构成问题事务分解成各个对象,关注的是解决问题需要那些对象。

三. 构造函数的推导

推导过程🌟:面向对象 => 对象 => 创建对象 => 代码冗余 => 工厂函数 => 识别问题 => 以系统对象为参考 => 推导出构造函数

详细的推导过程

  1. 首先,创建一个对象,添加属性和方法

    let obj1 = new Object();
    obj1.name = 'zs';
    obj1.age = 18;
    obj1.showinfo = function () {
        console.log(`我的名字叫${this.name},我今年${this.age}`);
    };
    obj1.showinfo() // 我的名字叫zs,我今年18岁
    

    提到创建一个对象,是不是想问,可不可以创建多个对象=>可以,最原始的方法:重复创建。

    let obj1 = new Object();
    obj1.name = 'zs';
    obj1.age = 18;
    obj1.showinfo = function () {
        console.log(`我的名字叫${this.name},我今年${this.age}`);
    }
    
    let obj2 = new Object();
    obj2.name = 'lisi';
    obj2.age = 17;
    obj2.showinfo = function () {
        console.log(`我的名字叫${this.name},我今年${this.age}`);
    }
    
    let obj3 = new Object();
    obj3.name = 'wangwu';
    obj3.age = 19;
    obj3.showinfo = function () {
        console.log(`我的名字叫${this.name},我今年${this.age}`);
    }
    
  2. 显然上述创建多个对象的方式非常的麻烦,而且造成了代码的冗余,此时有什么办法可以解决呢❓ => 函数封装

    function createPerson(name, age) { 
        let obj = new Object();
        obj.name = name
        obj.age = age;
        obj.showinfo = function () {
            console.log(`我的名字叫${this.name},我今年${this.age}`);
        };
        return obj;
    }
    
    let obj1 = createPerson('zs', 18);
    console.log(obj1.name); // zs
    obj1.showinfo(); // 我的名字叫zs,我今年18岁
    
    let obj2 = createPerson('lisi', 17);
    console.log(obj2.name); // lisi
    obj2.showinfo(); // 我的名字叫lisi,我今年17岁
    
    let obj3 = createPerson('wangwu', 19);
    console.log(obj3.name); // wangwu
    obj3.showinfo(); // 我的名字叫wangwu,我今年19岁
    

    :封装完成,可以解决创建多个对象代码冗余问题,而且将这一函数称之为工厂函数

  3. 此时,使用函数封装确实可以解决创建多个对象代码冗余问题,但是工厂函数无法解决识别问题。无法像Array,Date一样虽然属于对象,拥有自己独立的名称。

    因为创建的对象都是基于new Object()完成的,通过工厂函数看得见的。

    function createPerson(name, age) { // 工厂函数
        let obj = new Object();
        obj.name = name
        obj.age = age;
        obj.showinfo = function () {
            console.log(`我的名字叫${this.name},我今年${this.age}`);
        };
        return obj;
    }
    
  4. 继续以系统对象为参考,于是在调用函数的前面添加new关键字,得到最终构造函数。

    构造函数:new关键字调用,首字母大写,根据前面的概念,构造函数就是类,同时也知道系统的类是如何产生的。

    以 new 操作符调用函数的时候,函数内部发生以下变化:

    1.创建一个空对象,并且this变量引用该对象,同时还继承了该函数的原型。

    2.属性和方法被加入到this引用的对象中。

    3.并且最后隐式的返回this。

    function CreatePerson(name, age) { // 构造函数,构造函数里面的this指向实例对象,createPerson:类(构造函数)
        this.name = name; // 属性
        this.age = age; // 属性
        this.showinfo = function () { // 方法
            console.log(`我的名字叫${this.name},我今年${this.age}`);
        };
    }
    
    let obj1 = new CreatePerson('zs', 18); // obj1:实例对象
    console.log(obj1.name);
    obj1.showinfo();
    
    let obj2 = new CreatePerson('lisi', 17); // obj2:实例对象
    console.log(obj2.name);
    obj2.showinfo();
    
    let obj3 = new CreatePerson('wangwu', 19); // obj3:实例对象
    console.log(obj3.name);
    obj3.showinfo();
    

    :构造函数里面不要书写return

    因为构造函数里没有显式调用return,默认返回的是this对象,也就是新创建的实例对象。

四. 构造函数

(1) 概念

构造函数其实就是一个函数,只不过使用的时候需要和new 关键字连用,首字母大写。

和普通函数一样, 只不过调用的时候要和 new 调用 ,不然就是一个普通函数调用

const fn = function(age) {
    let a = 1; // 块作用域,外面无法获取,内部使用
    var b = 2; // 局部变量,外面无法获取,内部使用
    this.age = age; // 属性,实例对象可以自由获取,this->实例对象    
};

let f1 = new fn(18);
let f2 = new fn; // 这种写法也支持,弊端是无法传递参数

注意: 不写 new 的时候就是普通函数调用,没有创造对象的能力,但如果只是首字母不大写,只要和 new 连用,就有创造对象的能力。

(2) 构造函数特点总结

  1. 首字母大写(推荐)

    方便区分

  2. 构造函数里面不要书写return

    构造函数里没有显式调用return,默认返回的是this对象,也就是新创建的实例对象。

    当构造函数里调用return时,分两种情况:

    ​ 1.return的是五种简单数据类型:String,Number,Boolean,Null,Undefined。

    ​ 这种情况下,忽视return值,依然返回this对象。

    ​ 2.return的是Object

    ​ 这种情况下,不再返回this对象,而是返回return语句的返回值。

  3. 构造函数的调用必须和new连用

    只有和new连用,才有构造函数的能力,不和new连用,就是一个普通函数

  4. 构造函数的this

    构造函数的this指向:本次调用被自动创建的对象

    • 自动创建出来的对象叫做 实例对象
    • 这个创建对象的过程叫做 实例化 的过程
  5. 箭头函数没有this , 构造函数不能使用箭头函数书写

(3) 构造函数案例

创建拖拽的构造函数📝

<style>
    .box {
        width: 100px;
        height: 100px;
        background-color: red;
        position: absolute;
    }
    .box1 {
        width: 100px;
        height: 100px;
        background-color: blue;
        position: absolute;
        left: 300px;
    }
    .box2 {
        width: 100px;
        height: 100px;
        background-color: orange;
        position: absolute;
        left: 600px;
    }
</style>

<body>
    <div class="box"></div>
    <div class="box1"></div>
    <div class="box2"></div>
</body>
<script>
    function Drag(selector) { // 创建拖拽的构造函数
        // this -> 实例对象
        this.box = document.querySelector(selector); // 属性
        this.init = function () { // 初始化方法
            this.box.onmousedown = (e) => {
                e = e || event;
                let sx = e.offsetX;
                let sy = e.offsetY;
                document.onmousemove = (e) => {
                    e = e || event;
                    this.box.style.left = e.clientX - sx + 'px';
                    this.box.style.top = e.clientY - sy + 'px';
                };
                document.onmouseup = () => {
                    document.onmousemove = null;
                }
            }
        };
    }
    // let d1 = new Drag('.box');
    // d1.init();
    // let d1 = new Drag;
    // d1.init();
    new Drag('.box').init();
    new Drag('.box1').init();
    new Drag('.box2').init();
</script>

效果图
请添加图片描述

结束语

希望对您有一点点帮助,如有错误欢迎小伙伴指正。
👍点赞:您的赞赏是我前进的动力!
⭐收藏:您的支持我是创作的源泉!
✍评论:您的建议是我改进的良药!
一起加油!!!💪💪💪

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

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

相关文章

面试题:Redis网络模型

1 用户空间和内核空间以Centos 7 linux操作系统为例。计算机系统被内核操控&#xff0c; 内核被应用操控。为了避免用户应用导致冲突甚至内核崩溃&#xff0c;用户应用与内核是分离的进程的寻址空间会划分为两部分:内核空间、用户空间。用户空间只能执行受限的命令(Rin3&#x…

解决Mac 安装应用提示:xx已损坏,无法打开。 您应该将它移到废纸篓问题

许多新手mac 用户安装应用得时候会出现 “已损坏&#xff0c;无法打开。您应该将它移到废纸娄” 导致无法正常安装&#xff0c;其实应用软件b并没有损坏&#xff0c;只是系统安全设置&#xff0c;我们改如何解决呢&#xff1f; 1、开启允许任何来源 苹果已经取消了允许“任何…

以数据驱动管理场景,低代码助力转型下一站

数据驱动 数据驱动&#xff0c;是通过移动互联网或者其他的相关软件为手段采集海量的数据&#xff0c;将数据进行组织形成信息&#xff0c;之后对相关的信息讲行整合和提炼&#xff0c;在数据的基础上经过训练和拟合形成自动化的决策模型&#xff0c;简单来说&#xff0c;就是…

Python项目实战——外汇牌价(附源码)

前言 几乎每个人都在使用银行卡&#xff0c;今天我们就来爬取某行外汇牌价&#xff0c;获取我们想要的数据。 环境使用 python 3.9pycharm 模块使用 requests 模块介绍 requestsrequests是一个很实用的Python HTTP客户端库&#xff0c;爬虫和测试服务器响应数据时经常会用到&…

5分钟搞懂 强缓存与协商缓存

Ⅰ、http缓存 HTTP 缓存策略 分为 > 「强制缓存」 和 「协商缓存」 为什么需要 HTTP 缓存 呢 ? &#x1f447; 直接使用缓存速度 >> 远比重新请求快 缓存对象有那些呢 &#xff1f;&#x1f447; 「图片」 「JS文件」 「CSS文件」 等等 文章目录Ⅰ、http缓存Ⅱ…

震惊!邻桌的程序猿做可视化报告竟然比我还快,带着好奇心我打开了他的电脑,发现惊天秘密,原因竟是...

其实&#xff0c;本文就是想分享一个做可视化的捷径&#xff01; 制作可视化的方式有千千万。 Excel 控若能轻车熟路驾驭 VBA&#xff0c;能玩出各种花来&#xff0c;再不济借助图表插件外援也能秒杀一众小白选 手。 会编程的&#xff0c;Echarts 几十行代码&#xff0c;分分…

Flink反压如何排查

Flink反压利用了网络传输和动态限流。Flink的任务的组成由流和算子组成&#xff0c;那么流中的数据在算子之间转换的时候&#xff0c;会放入分布式的阻塞队列中。当消费者的阻塞队列满的时候&#xff0c;则会降低生产者的处理速度。 如上图所示&#xff0c;当Task C 的数据处…

nuxt 学习笔记

这里写目录标题路由跳转NuxtLinkquery参数params参数嵌套路由tab切换效果layouts 文件夹强制约定放置所有布局文件&#xff0c;并以插槽的形式作用在页面中1.在app.vue里面2.component 组件使用Vue < component :is"">Vuex生命周期数据请求useFetchuseAsyncDat…

鸿蒙设备学习|快速上手BearPi-HM Micro开发板

系列文章目录 第一章 鸿蒙设备学习|初识BearPi-HM Micro开发板 第二章 鸿蒙设备学习|快速上手BearPi-HM Micro开发板 文章目录系列文章目录前言一、环境要求1.硬件要求2.软件要求3.Linux构建工具要求4.Windows开发工具要求5.工具下载地址二、安装编译基础环境1.安装Linux编译环…

【速通版】吴恩达机器学习笔记Part1

准备速通一下吴恩达的机器学习 很快做个笔记5.2.3 监督学习 part 2_哔哩哔哩_bilibili 1.概述&#xff08;P1-P3) ML是AI的重要部分&#xff0c;AI的目标是AGI&#xff08;artificial general intelligence&#xff09;但是目前就。。。。 supervised learning&#xff1a;目…

如何开发L2毫秒接口?

L2毫秒接口普遍应用于大众的日常生活中&#xff0c;并且很多的企业通过api进行数据内容的调用&#xff0c;从而在技术上和成本上得到福利。 进行数据的整合与共享是L2毫秒接口的主要用途之一&#xff0c;所以开发L2毫秒接口就必须慎重&#xff0c;注意安全隐患&#xff0c;防止…

VHDL语言基础-组合逻辑电路-其它组合逻辑模块

目录 多路选择器&#xff1a; 逻辑功能&#xff1a; 常用的类型&#xff1a; 4选1多路选择器的实现&#xff1a; 求补器&#xff1a; 求补器的实现&#xff1a; 三态门&#xff1a; 三态门的应用实例&#xff1a; 三态门的实现&#xff1a; 缓冲器&#xff1a; 什么是…

Lesson 6.4 逻辑回归手动调参实验

文章目录一、数据准备与评估器构造1. 数据准备2. 构建机器学习流二、评估器训练与过拟合实验三、评估器的手动调参在补充了一系列关于正则化的基础理论以及 sklearn 中逻辑回归评估器的参数解释之后&#xff0c;接下来&#xff0c;我们尝试借助 sklearn 中的逻辑回归评估器&…

Ts笔记第一天

文章目录安装 ts运行环境 nodeTS类型数字 、字符串 和布尔类型字面量any 和unknown类型断言void和neverobjectArraytuple 元组enum 枚举安装 ts运行环境 node node-v看版本号 2. 安装ts -g全局安装 npm i -g typescript // 这里全局安装 -s安装无法使用tsc 创建一个01.ts文…

第五十章 动态规划——数位DP模型

第五十章 动态规划——数位DP模型一、什么是数位DP数位DP的识别数位DP的思路二、例题1、AcWing 1083. Windy数&#xff08;数位DP&#xff09;2、AcWing 1082. 数字游戏&#xff08;数位DP&#xff09;3、AcWing 1081. 度的数量&#xff08;数位DP&#xff09;一、什么是数位DP…

供应PEG试剂AC-PEG-COOH,Acrylate-PEG-Acid,丙烯酸酯-PEG-羧基

英文名称&#xff1a;AC-PEG-COOH&#xff0c;Acrylate-PEG-Acid 中文名称&#xff1a;丙烯酸酯-聚乙二醇-羧基 丙烯酸酯-PEG-COOH是一种含有丙烯酸酯和羧酸的线性杂双功能PEG试剂。它是一种有用的带有PEG间隔基的交联剂。丙烯酸酯可与紫外光或自由基引发剂聚合。丙烯酸酯-PE…

从FPGA说起的深度学习(二)

这是新的系列教程&#xff0c;在本教程中&#xff0c;我们将介绍使用 FPGA 实现深度学习的技术&#xff0c;深度学习是近年来人工智能领域的热门话题。在本教程中&#xff0c;旨在加深对深度学习和 FPGA 的理解。用 C/C 编写深度学习推理代码高级综合 (HLS) 将 C/C 代码转换为硬…

Leetcode.1797 设计一个验证系统

题目链接 Leetcode.1797 设计一个验证系统 Rating : 1534 题目描述 你需要设计一个包含验证码的验证系统。每一次验证中&#xff0c;用户会收到一个新的验证码&#xff0c;这个验证码在 currentTime时刻之后 timeToLive秒过期。如果验证码被更新了&#xff0c;那么它会在 curr…

完成各种项目生态环评工作丨全流程基于最新导则下的生态环境影响评价技术方法及图件制作与案例

目录 专题一 生态环境影响评价框架及流程 专题二 基于遥感解译的土地利用现状图的编制 专题三 生物多样性测定及R语言分析 专题四 植被类型及植被覆盖度图的编制 专题五 生物量与净初级生产力测定&#xff1a;实测及模型 专题六 生态系统类型及服务价值评估 专题七 物种…

【漫漫转码路】Day 45 机器学习 day04

梯度下降 梯度下降法是常用于求解无约束情况下凸函数的极小值&#xff0c;是一种迭代类型的算法&#xff0c;因为凸函数只有一个极值点&#xff0c;故求解出来的极小值点就是函数的最小值点 公式 第一个θ&#xff0c;是更新之后的θ&#xff0c;第二个θ是更新之前的θ&…