【JavaScript】面向对象和构造函数详解

news/2024/4/29 18:45:54/文章来源:https://blog.csdn.net/qq_45867247/article/details/128945140

💻 【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 = nameobj.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 = nameobj.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.luyixian.cn/news_show_255633.aspx

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

相关文章

加拿大访问学者家属如何办理探亲签证?

由于大多数访问学者的访学期限都为一年&#xff0c;家人来访不仅可以缓解访学的寂寞生活&#xff0c;而且也是家人到加拿大体验国外风情的好机会。家属在国内申请赴加签证时&#xff0c;如果材料齐全&#xff0c;一般上午递交了申请&#xff0c;下午就可以拿到签证。以下是家人…

基于merlin使用chatGPT进行对话

最近chatGPT很热&#xff0c;大家都想试用它。但由于各种限制&#xff0c;一般情况下国内不能试用。 下面给大家介绍基于merlin使用chatGPT&#xff08;目前每天只有11次问答次数&#xff09;。 1 打开merlin页面 访问地址merlin.foyer.work&#xff0c;点击“add to chrome”…

流程控制之循环

文章目录五、流程控制之循环5.1 步进循环语句for5.1.1 带列表的for循环语句5.1.2 不带列表的for循环语句5.1.3 类C风格的for循环语句5.2 while循环语句5.2.1 while循环读取文件5.2.2 while循环语句示例5.3 until循环语句5.4 select循环语句5.5 嵌套循环5.4 利用break和continue…

Elasticsearch安装IK分词器、配置自定义分词词库

一、分词简介 在Elasticsearch中&#xff0c;假设搜索条件是“华为手机平板电脑”&#xff0c;要求是只要满足了其中任意一个词语组合的数据都要查询出来。借助 Elasticseach 的文本分析功能可以轻松将搜索条件进行分词处理&#xff0c;再结合倒排索引实现快速检索。Elasticse…

crawler爬虫抓取数据

crawler爬虫实现 学习目标&#xff1a; 了解 crawler爬虫运行流程了解 crawler爬虫模块实现 1. crawler功能 初始化driver输入公司名称,并点击判断是否需要验证如果需要验证&#xff0c;获取验证图片并保存获取打码坐标点击验证图片判断查询结果选择第一条查询结果获取主要信…

Vue2仿网易云风格音乐播放器(附源码)

Vue2仿网易云风格音乐播放器1、整体效果2、使用技术3、实现内容4、源码5、使用图片1、整体效果 2、使用技术 使用了HTML5 CSS3进行页面布局及美化使用Vue2进行数据渲染与页面交互使用Axios发送http请求获取数据 3、实现内容 实现了搜索歌曲功能&#xff0c;输入歌手或歌曲关…

2023年做跨境电商的4个小忠告

2023年做跨境电商的小伙伴日益增加&#xff0c;但不管是对于新手还是老人&#xff0c;都是一个极具挑战的事情&#xff0c;因为做好跨境电商不是一件容易的事情&#xff0c;需要花费不少时间与精力。这里我们小编就给大家几个小忠告&#xff0c;希望对大家有用。2023年做跨境电…

私募证券基金动态-23年1月报

成交量&#xff1a;1月日均7,901.31亿元2023年1月A股两市日均成交7,901.31亿元&#xff0c;环比上升0.33%、同比下降25.18%。1月恰逢春节仅16个交易日&#xff0c;节后2个交易日交易量明显回暖。管理人&#xff1a;新提交备案51家&#xff0c;备案通过21家1月新提交备案申请的5…

侯捷C++系统工程师

前言我相信对于每一个学习C的同学和从业者来说&#xff0c;台湾著名学者侯捷老师的C系列都是不可错过的好视频。侯捷老师在网上已有五门课&#xff0c;分别是&#xff1a;C面向对象开发、STL标准库与泛型编程、C新标准C1&14、C内存管理机制以及C Startup揭秘讲师介绍侯捷老…

当下最流行的 ChatGPT :前世今生

GPT 不是凭空而出&#xff0c;它是经过了很多人的努力&#xff0c;以及很长一段时间的演化得来的。因此&#xff0c;梳理一下 GPT 的庞大 “家族” 还是很有必要的&#xff0c;看看他继承了什么&#xff0c;学习了什么&#xff0c;又改进了什么&#xff0c;这样也能更好地理解 …

微店商品详情API

一、微店的定义&#xff1a; 随着移动互联网应用微信的崛起&#xff0c;微商生态随着移动电商领域兴起&#xff0c;作为承载微商的平台微店就此产生。所谓“微店”&#xff0c;本质上就是提供让微商玩家入驻的平台&#xff0c;有点类似PC端建站的工具&#xff0c;其不同于移动…

设计模式-工厂模式 Factory Pattern(简单工厂、工厂方法、抽象工厂)

工厂模式 Factory Pattern&#xff08;简单工厂、工厂方法、抽象工厂&#xff09; 工厂模式-创建型模式-提供了创建对象的最佳方式。 在工厂模式中&#xff0c;创建对象时不会对客户端暴露创建逻辑&#xff0c;并且是通过一个共同的接口来创建新的对象。 简单工厂 简单工厂…

小兔子MQ高级

一.保证消息被执行处理传递逻辑&#xff1a;生产者消息确认RabbitMQ提供了publisher confirm机制来避免消息发送到MQ过程中丢失。这种机制必须给每个消息指定一个唯一ID(一般是业务id)。消息发送到MQ以后&#xff0c;会返回一个结果给发送者&#xff0c;表示消息是否处理成功。…

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

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

真的麻了,别再为难软件测试员了......

前言 有不少技术友在测试群里讨论&#xff0c;近期的面试越来越难了&#xff0c;要背的八股文越来越多了,考察得越来越细&#xff0c;越来越底层&#xff0c;明摆着就是想让我们徒手造航母嘛&#xff01;实在是太为难我们这些测试工程师了。 这不&#xff0c;为了帮大家节约时…

无需注册即可免费使用ChatGPT

无需注册即可免费使用ChatGPT 最近OpenAI的ChatGPT异常火爆&#xff0c;有很多人都想尝试尝试&#xff0c;但是因为一些原因折戟&#xff0c;这里提供一个免注册的体验方法&#xff0c;仅供学习交流。 一&#xff0c;首先下载vscode 官网下载地址 Visual Studio Code - Code…

【python】多线程的基本使用 _thread包

Python中使用线程有两种方式&#xff1a;函数或者用类来包装线程对象。 函数式&#xff1a; 调用 _thread 模块中的start_new_thread()函数来产生新线程。语法如下: _thread.start_new_thread ( function, args[, kwargs] ) 参数说明: function - 线程函数。 args - 传递给线…

后勤管理系统—服务台管理功能

数图互通是一家IT类技术型软件科技公司&#xff0c;专业的不动产、工作场所、空间、固定资产、设备家具、设施运维及可持续性管理解决方案软件供应商。 一、后勤管理系统服务台管理功能包含&#xff1a; 1、专业自动化、集中管理的自助服务助理&#xff0c;随时响应服务请求。…

《数字经济全景白皮书》出海篇:选对路径下好棋,热点出海行业如何实现增长?

易观分析&#xff1a;《数字经济全景白皮书》浓缩了易观分析对于数字经济各行业经验和数据的积累&#xff0c;并结合数字时代企业的实际业务和未来面临的挑战&#xff0c;以及数字技术的创新突破等因素&#xff0c;最终从数字经济发展大势以及各领域案例入手&#xff0c;帮助企…

mongo DB数据库bindIP的配置和我的理解(bindIP不是应用服务器的IP)

先批评这个文章&#xff01;典型的错误&#xff0c;bindIP根本不是绑定哪一个ip的 背景&#xff1a;最近在阿里云上搭建overleaf的web服务集群&#xff0c;数据库和应用服务器分离&#xff0c;一口气买了三台服务器准备开始干活。overleaf用的是mongodb&#xff0c;我本来准备…