前端面试题 | new 操作符的原理 |(对象的原型 及其用途)

问题:new操作符具体干了什么?

总结:

在JavaScript中,new操作符 用于创建一个新的对象实例

作用是 ①创建一个空对象 ②将这个新对象的隐式原型指向构造函数的显式原型 ③它将构造函数的this指向这个新对象,并执行构造函数中的代码,初始化这个新对象 ④返回对象。

在使用new操作符时,需要注意构造函数必须使用new操作符来调用,否则this将指向全局对象。同时,构造函数中

不需要显式地返回一个对象----》new操作符会自动返回新创建的对象,即obj;

显式返回一个对象-----》 返回 return后面的内容/引用类型,即 res,也就是 Fun.apply(obj)


目录

new 操作符的原理/执行过程

(1)创建了一个新的空对象 ---> let obj = {};

(2)将空对象和构造函数通过原型连接起来

(3)将构造函数中的 this 绑定给新对象

(4)返回对象

实现 new 操作符(几种写法)

其他知识点

对象的原型

(1)隐式原型

(2)显式原型

原型的用途

 this指向


new 操作符的原理/执行过程

(1)创建了一个新的空对象 ---> let obj = {};
(2)将空对象和构造函数通过原型连接起来

<---> 构造函数的显示原型 赋值给 对象的隐式原

<---> obj._proto_ = Fun.prototype,即 将对象的 _proto_属性 指向 构造函数的 prototype对象

设置新对象的 constructor 属性为构造函数的名称,设置新对象的 proto 属性指向构造函数的 prototype 对象; obj._proto_ = Fun.prototype; ----> 扩展了 新对象的原型链 

(3)将构造函数中的 this 绑定给新对象

将构造函数的 this 指向创建的对象

方法:构造函数.call(新对象)  或 构造函数.apply(新对象,参数)

                即  let  res = Fun.call(obj)  或 Fun.apply(obj, args)

new 操作符会调用指定的构造函数,并将 新创建的对象作为 构造函数的 this 上下文

----> 构造函数内部可以使用 this 来访问和修改 新对象的属性。

(4)返回对象

几种说法:

  • 若构造函数没有返回空对象,那么自动返回创建出来的新对象。
  • 判断函数的返回值类型,若为值类型,则返回创建的对象;若为引用类型,则返回这个引用类型的对象。
  • 构造函数一般没有显示返回,new操作符自动返回新创建的对象作为结果;若构造函数显示返回,返回对象会覆盖默认返回的新对象。
  • 返回 this 指针。当存在显示的返回时,返回 return 后面的内容。新建的空对象作废。

即 return res instanceof Object ? res : obj

----》☆ 存在显式返回,为引用类型,返回 res;不存在显式返回,为值类型,返回 obj

实现 new 操作符(几种写法)

const _new = function(Fun,...args) {
    // 1. 创建空对象  
    let obj = Object.create(null)
    // 2. 将对象与构造函数通过原型连接
    // 将 构造函数的显式原型 赋值给 对象的隐式原型
    // 等价于 obj._proto_ = Fun.prototype
    Object.setPrototypeOf(obj, Fun.prototype)
    // 3. 将构造函数的this指向对象,并向函数传参
    let res = Fun.apply(obj, args)
    // 4. 确保返回的是一个对象
    return res instanceof Object ? res : obj
}
const _new = function(Fun,...args) {
    let obj = {}
    obj._proto_ = Fun.prototype
    let res = Fun.apply(obj, args)
    return res instanceof Object ? res : obj
}
const _new = function(Fun,...args) {
    let obj = Object.create(Fun.prototype)
    let res = Fun.apply(obj, args)
    return res instanceof Object ? res : obj
}

其他知识点

对象的原型
(1)隐式原型

        - 每个对象都有一个[[ Prototype ]],称为对象的原型(隐式原型)。

        - 对象的原型不是直接显示的,采用以下的方法查看

                ① obj._proto_

                ② Object.getPrototypeOf(obj)    注:es5以后

(2)显式原型

可以直接通过 prototype 属性获取

☆原型总结:隐式原型---> _proto_

                     显式原型---> prototype

原型的用途

找对象的属性时,会触发 getter 操作

① 先看自己对象中有无该对象,若有,直接用

② 没有,则沿着原型中查找,直到找到 Object 的原型,Object 的原型为 null

 this指向

通过 call 或 apply 方法进行指定

参考的文献:
前端经典面试题 | New操作符的原理_new操作符的实现原理-CSDN博客

new操作符的实现原理及几种手写方法-CSDN博客

new的操作符具体做了什么?_js new操作符做了什么-CSDN博客

2023Web前端开发八股文&面试题(万字系列)——这篇就够了!_前端八股文-CSDN博客(js 1.13)

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

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

相关文章

在Leaflet中点对象使用SVG和Canvas两种模式的对比

目录 前言 一、关于SVG和Canvas 1、SVG知识 2、Canvas知识 3、优缺点 二、SVG和Canvas在Leaflet的使用 1、相关类图 2、Leaflet的默认展示方式 三、SVG和Canvas实例及性能对比 1、SVG模式及性能对比 2、Canvas优化 总结 前言 众所周知&#xff0c;在Leaflet当中&#…

vue3配置element-plus时间选择器中文显示

修改main.js import ElementPlus from element-plus import element-plus/dist/index.css // 引入中文包 import zhCn from "element-plus/es/locale/lang/zh-cn"; const app createApp(App) app.use(ElementPlus,{ locale: zhCn, }) //挂载 app.mount(#app)

白盒测试:覆盖测试及测试用例设计

白盒测试&#xff1a;覆盖测试及测试用例设计 一、实验目的 1、掌握白盒测试的概念。 2、掌握逻辑覆盖法。 二、实验任务 某工资计算程序功能如下&#xff1a;若雇员月工作小时超过40小时&#xff0c;则超过部分按原小时工资的1.5倍的加班工资来计算。若雇员月工作小时超过…

数据库系统理论——关系数据库

文章目录 一、关系&#xff08;数据结构&#xff09;1、概述2、名词解释3、关系模式、关系数据库、关系数据库模式4、基本关系的性质 二、关系操作&#xff08;数据操作&#xff09;三、关系的完整性1、实体完整性2 、参照完整性3、用户自定义的完整性 四、关系代数五、习题 前…

Twitch赠送暗区突围测试资格 超简单暗区突围测试资格领取教程

作为直播界的领航者&#xff0c;Twitch平台不仅是全球游戏文化直播的中心舞台&#xff0c;更是频繁联袂各路游戏大作&#xff0c;为粉丝们奉上别具匠心的互动盛宴&#xff0c;让观赛的同时解锁诱人的游戏内惊喜。正值《暗区突围》PC版测试的热潮涌动&#xff0c;Twitch乘势加强…

详细分析McCabe环路复杂度(附例题)

目录 前言1. 基本知识2. 例题 前言 该知识点常出在408或者软考中&#xff0c;对此此文重点讲讲理论知识以及例题 对于例题平时看到也会更新 1. 基本知识 McCabe环路复杂度是一种用于衡量软件代码复杂性的指标&#xff0c;主要是通过计算代码中的控制流图中的环路数量来衡量…

华为数据之道第一部分导读

目录 导读 第一部分 序 第1章 数据驱动的企业数字化转型 非数字原生企业的数字化转型挑战 业态特征&#xff1a;产业链条长、多业态并存 运营环境&#xff1a;数据交互和共享风险高 IT建设过程&#xff1a;数据复杂、历史包袱重 数据质量&#xff1a;数据可信和一致化…

逆向中webpack需要补充的模块很多怎么办

如下面这种典型的形式 进入i找到加载器 找到加载器所在函数r,在 return e[a].call(c.exports, c, c.exports, r),打上断点。 在控制台打印e,会发现它总共有的模块&#xff0c;这些模块需要我们在别的webpack中复制&#xff0c;有时很多&#xff0c;很麻烦。 我们可以注入代码在…

es6语法总结

【1】语法 &#xff08;1&#xff09;声明变量(let-var-const) 变量提升&#xff1a; 是JavaScript引擎在代码执行前将变量的声明部分提升到作用域顶部的行为。尽管变量的声明被提升了&#xff0c;变量的赋值&#xff08;即初始化&#xff09;仍然保留在原来的位置。因此&…

紫外激光打标机适合在哪些材料表面进行标记

紫外激光打标机适合在多种材料表面进行标记&#xff0c;特别是那些对热敏感或者需要高精度、高清晰度标记的材料。以下是一些常见的适用材料&#xff1a; 1. 塑料&#xff1a;紫外激光打标机在塑料材料上表现尤为出色&#xff0c;因为紫外激光的短波长和高能量密度使得它能够在…

基于树莓派的六足机器人方案设计+源代码+工程内容说明

文章目录 源代码下载地址项目介绍项目内容说明简单预览 项目备注源代码下载地址 源代码下载地址 点击这里下载源码 项目介绍 项目内容说明 hardware为项目相关硬件设计 机械结构为六足机器人的3d建模工程&#xff0c;包括本体和云台遥控器在ESP32最小开发板上集成了MPU605…

ChatGPT DALL-E绘图,制作各种表情包,实现穿衣风格的自由切换

DALL-E绘图功能探索&#xff1a; 1、保持人物形象一致&#xff0c;适配更多的表情、动作 2、改变穿衣风格 3、小女孩的不同年龄段展示 4、不同社交平台的个性头像创作 如果不会写代码&#xff0c;可以问GPT。使用地址&#xff1a;我的GPT4 视频&#xff0c;B站会发&#…

茅台申购,多平台签到与通知 | 使用极空间NAS部署一个神级脚本『DailyCheckIn』

茅台申购&#xff0c;多平台签到与通知 | 使用极空间NAS部署一个神级脚本『DailyCheckIn』 哈喽小伙伴们好&#xff0c;我是Stark-C~&#xff0c;今天为大家分享一个极空间上非常实用且好玩的项目。 小伙伴们都知道&#xff0c;目前很多平台为了促进用户的活跃度和黏性&#…

ENVI拓展工具资源去哪里找

ENVI拓展工具资源去哪里找&#xff1f; 文章目录 ENVI拓展工具资源去哪里找&#xff1f;前言网站&#xff08;链接见文末&#xff09;ENVI应用商店&#xff08;App Store&#xff09;ENVI官方提供第三方制作自己制作 总结参考 前言 ENVI 拓展工具是指 ENVI 软件的扩展功能或插…

WordPress插件:链接自动识别转为超链接

WordPress插件&#xff1a;链接自动识别转为超链接 <?phpfunction open_links_in_new_tab() {add_filter(the_content, make_clickable);function autoblank($text) {$return str_replace(<a, <a target"_blank", $text);return $return;}add_filter(th…

海外市场成 ISV 新掘金地?生成式 AI 如何加速业务创新实践?Zilliz 有话说

期望了解 Zilliz 最新动态&#xff1f;想要与 Zilliz 线下探讨 AI 时代向量数据库的全球化布局思考及典型实践&#xff1f; 机会来啦&#xff01;5 月 10 日&#xff0c;Zilliz 将闪现亚马逊云科技的两场活动现场&#xff08;苏州、西安&#xff09;&#xff0c;与大家共话行业…

【Kubernetes集群一主二从安装教程】

文章目录 环境准备主机间做信任安装ansible工具 升级内核版本使用elrepo源升级内核查看最新版内核安装最新的内核版本设置系统默认内核设置默认内核为我们刚才升级的内核版本 初始化关闭防火墙关闭selinux关闭swap修改主机名修改hosts文件将桥接的IPv4流量传递到iptables的链配…

52岁前宝丽金小花懒理旧爱郭晋安离婚,大晒美腿甜蜜放闪

TVB三届视帝郭晋安与欧倩怡早前在社交平台共同宣布离婚&#xff0c;并透露二人已分居两年&#xff0c;18年夫妻情画上句号&#xff0c;惊爆全城。郭晋安曾受访指&#xff0c;遇上欧倩怡前只有两段深刻的感情&#xff0c;一段是初恋&#xff0c;另一段则是刘小慧。 旧爱刘小慧懒…

贪吃蛇游戏(C语言实现)

目录 游戏效果展示文件代码的展示test.cSnake.cSnake.h 下一个坐标不是食物 游戏效果展示 QQ录屏20240507163633 文件 代码的展示 test.c #define _CRT_SECURE_NO_WARNINGS#include<locale.h> //设置本地化 #include"Snake.h"//游戏的测试逻辑 void test() {…

【服务治理中间件】consul介绍和基本原理

目录 一、CAP定理 二、服务注册中心产品比较 三、Consul概述 3.1 什么是Consul 3.2 Consul架构 3.3 Consul的使用场景 3.4 Consul健康检查 四、部署consul集群 4.1 服务器部署规划 4.2 下载解压 4.3 启动consul 五、服务注册到consul 一、CAP定理 CAP定理&#xff…
最新文章