#yyds干货盘点# 前端歌谣的刷题之路-第一百五十九题-new

简介: #yyds干货盘点# 前端歌谣的刷题之路-第一百五十九题-new

题目

请补全JavaScript代码,要求实现对象参数的深拷贝并返回拷贝之后的新对象。

注意:

1. 参数对象和参数对象的每个数据项的数据类型范围仅在数组、普通对象({})、基本数据类型中]

2. 无需考虑循环引用问题

image.png

编辑

核心代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>new</title>
</head>
<body>
  <script type="text/javascript">
    const _new = function (constructor, ...args) {
      // new关键字做了4件事
      // 1. 创建一个新对象
      const obj = {};
      // 2. 为新对象添加属性__proto__,将该属性链接至构造函数的原型对象
      obj.__proto__ = constructor.prototype;
      // 3. 执行构造函数,this被绑定在新对象上
      const res = constructor.apply(obj, args);
      // 4. 确保返回一个对象
      return res instanceof Object ? res : obj;
    };
  </script>
</body>
</html>
相关文章
|
2月前
|
前端开发 开发者
new操作符背后的秘密:揭开Web前端对象创建的神秘面纱!
【8月更文挑战第23天】在Web前端开发中,`new`操作符是创建对象实例的核心。本文以`Person`构造函数为例,通过四个步骤解析`new`操作符的工作原理:创建空对象、设置新对象原型、执行构造函数并调整`this`指向、判断并返回最终对象。了解这些有助于开发者更好地理解对象实例化过程,从而编写出更规范、易维护的代码。
29 0
|
5月前
|
前端开发 JavaScript
【Web 前端】new操作符具体都干了什么?
【4月更文挑战第22天】【Web 前端】new操作符具体都干了什么?
|
前端开发
前端学习笔记202306学习笔记第三十七天-手写new得实现4
前端学习笔记202306学习笔记第三十七天-手写new得实现4
34 0
|
前端开发
前端经典面试题 | New操作符的原理
前端经典面试题 | New操作符的原理
|
前端开发
前端学习笔记202306学习笔记第三十七天-手写new得实现5
前端学习笔记202306学习笔记第三十七天-手写new得实现5
55 0
|
前端开发
前端学习笔记202306学习笔记第三十七天-手写new得实现3
前端学习笔记202306学习笔记第三十七天-手写new得实现3
52 0
|
前端开发
前端学习笔记202306学习笔记第三十七天-手写new得实现1
前端学习笔记202306学习笔记第三十七天-手写new得实现1
47 0
|
前端开发
前端学习笔记202306学习笔记第三十七天-手写new得实现2
前端学习笔记202306学习笔记第三十七天-手写new得实现2
47 0
|
前端开发 API
歌谣学前端之react三个api之一续集
歌谣学前端之react三个api之一续集
55 0
|
监控 JavaScript 前端开发
前端监控实战之 New Relic
前端监控实战之 New Relic
242 0
下一篇
无影云桌面