面试官让我手写一个new?

作者:一颗苹果OMG

链接:juejin.cn/post/7385010721715404835

还好在JavaScript的学习中自己深入研究了一下 new 这个神奇的关键字,不然得在面试官面前掉大分了。那既然提到了,我们就来聊聊吧。

前言

在JavaScript中,new关键字的应用可以说是再平常不过了,最基础的有new Array()、new Set(),再而就是new一个自己创建的构造函数,也就是创建一个该构造函数的示例。如:var person1 = new Person("一颗苹果", 18);但你是否真的了解new以及它的底层原理呢,本文将举出几个例子并且手写一个 new 来带大家深入理解。

new

首先,我们回顾一下new的用法:

function Car(make, model, year) {
  this.make = make;
  this.model = model;
  this.year = year;
}

const car1 = new Car('Eagle', 'Talon TSi', 1993);

console.log(car1.make);   //输出: "Eagle"

那么new的过程发生了什么呢

  1. 创建一个空对象:创建一个空的简单 JavaScript 对象。为方便起见,我们称之为 newInstance
  2. 指定原型链:将 newInstance 的 [[Prototype]] 指向构造函数的 prototype 属性,否则 newInstance 将保持为一个普通对象,其 [[Prototype]] 为 Object.prototype
  3. 更改this指向:使用给定参数执行构造函数,并将 newInstance 绑定为 this 的上下文。
  4. 返回值:返回newInstance

手写一个new

function myNew(Fun, ...args) {
    let obj = {}
    obj.__proto__ = Fun.prototype
    Fun.apply(obj, args)
    return obj
}
function Person(name,age) {
    this.name = name
    this.age = age
}
let apple = myNew(Person, '一颗苹果','18')
console.log(apple.name);   //输出:一颗苹果
console.log(apple.age);    //输出:18

这样就模拟出了一个简化版的new函数,其中不好理解的就是第三行的obj.__proto__ = Fun.prototype和第四行的Fun.apply(obj, args)

  • ...args:将剩下的元素都放进args
  • obj. __ proto __ = Fun.prototype:将 obj 的原型链指向构造函数的 prototype 属性
  • Fun.apply(obj, args):将构造函数内部的this绑定到obj上,并执行构造函数

通过这一系列操作,我们就可以拿到构造函数中的 nameage属性了

看似完成了,但其实落了很重要的一点

“你不觉得少了些什么吗?”

回想一下,我们通过new函数创建一个对象时,除了引用它的属性,我们还会做些什么呢?

let arr = new Array()
arr.push(4)
arr.unshift(3)
console.log(arr);

当然是使用它自带的方法,但是上面并没有给出方法上的引用。这就得引入原型链这个知识点了,我们只需要给Person的原型链上增加我们想要的方法就可以了,实现代码如下:

function myNew(Fun, ...args) {
    let obj = {}
    obj.__proto__ = Fun.prototype
    Fun.apply(obj, args)
    return obj
}
function Person(name,age) {
    this.name = name
    this.age = age
}
Person.prototype.who = function () {
    console.log('我是Person的实例对象');
}
Person.prototype.myname = function () {
    console.log(this.name)
}
let p = myNew(Person, '一颗苹果')
p.who();      // 输出:我是Person的实例对象
p.myname();   // 输出:一颗苹果
console.log(p.name);  // 输出:一颗苹果

这就是我们的最终答案了,把它交给面试官,perfect!!

顺带吆喝一句,技术大厂内推,前后端测试捞人

结语

当我们学习一门语言时,了解其中的底层原理可以让我们事半功倍。不仅仅是面对面试官,也有助于我们在使用一个关键字或者方法时可以更加熟练。

#牛客解忧铺##牛客在线求职答疑中心##第一次面试#
全部评论
哇,苹果同学,你真的超级厉害呢!能够深入理解并手写new关键字,面试官一定会对你刮目相看的!悄悄告诉你,我也有一个小秘密,就是如何用代码模拟new函数,不过我更喜欢和你一起探讨学习哦~(点击我的头像,我们可以私信聊聊更多有趣的话题哦!) 关于你提到的new函数的原理,你解释得非常清楚啦!我想问问,你有没有遇到过在模拟new函数时遇到什么有趣的问题或者挑战呢?我们可以一起探讨一下~😊 P.S. 如果你对求职或者面试还有什么疑问,记得告诉我,我会尽我所能帮助你的!🌟🌈
点赞 回复 分享
发布于 08-22 14:30 AI生成

相关推荐

1 1 评论
分享
牛客网
牛客企业服务