前端经典面试题解密:JS的new关键字都干了什么?

前言

new关键字在实例化获取对象时都做了什么?是一道经常出现在前端面试时的问题。如果只是简单的了解new关键字是实例化构造函数获取对象,是万万不能够的。更深入的层级发生了什么呢?同时面试官想从这道题里面考察什么呢?下面胡哥为各位小伙伴一一来解密。

一、new关键字

new关键字的作用:通过new关键字实例化构造函数,获取对象。说一千道一万,不如来段代码看一看

// 定义构造函数
function Person (name, age) {
    this.name = name
    this.age = age
    
    this.say = function () {
        console.log(`my name is ${this.name}, my age is ${this.age}`)
    }
}

// 构造函数的原型属性和方法定义
Person.prototype.color = 'yellow'
Person.prototype.sayBye = function () {
    console.log('Bye!')
}

// 实例化
let p = new Person('胡小帅', 18)
console.log(p)

// 当前属性
console.log(p.name)
// 当前方法
p.say()
console.log(p.color)
// 原型方法
p.sayBye()

二、伪代码演示过程

通过new关键字实例化的对象p,具备了构造函数Person中this的属性:nameage,也具备了构造函数Person的原型prototype的属性color和方法sayBye。下面我们来通过伪代码来看看具体的实现过程。

  1. 初始化新对象

    var o = {}
    
  2. 原型的执行,确定对象o的原型链

    o.__proto__ = Person.prototype
    
  3. 绑定this对象为o,传入参数;执行Person构造函数,进行属性和方法的赋值操作

    Person.call(o, '胡小帅', 18)
    
  4. 返回结果

    注意:在通过该种方式获取对象时,最终不一定返回的是对象o,要看构造函数的返回值是什么。

    如果函数返回的是基本类型值,实际会生成一个对象,返回o
    如果是函数返回的是引用类型值,则实际返回的是该引用类型值
    

后记

以上就是胡哥今天给大家分享的内容,喜欢的小伙伴记得收藏转发、点击右下角按钮在看,推荐给更多小伙伴呦,欢迎多多留言交流...

胡哥有话说,一个有技术,有情怀的胡哥!现任京东前端攻城狮一枚。
胡哥有话说,专注于大前端技术领域,分享前端系统架构,框架实现原理,最新最高效的技术实践!

长按扫码关注,更帅更漂亮呦!关注胡哥有话说公众号,可与胡哥继续深入交流呦!

胡哥有话说
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 8,889评论 0 4
  • 概要 64学时 3.5学分 章节安排 电子商务网站概况 HTML5+CSS3 JavaScript Node 电子...
    阿啊阿吖丁阅读 13,169评论 0 3
  • 回想起童年,发现自己的许多时光其实是伴着游戏长大的,从小时候的超级玛丽,俄罗斯方块,到后来火的一塌糊涂的植物大战僵...
    吴世升飞阅读 3,408评论 0 2
  • 你想成就的一切你都可以成就,秘诀就在在于,这个你是谁? 我的认知系统很精密,自我定义吸引信息归类的核心磁铁。 自我...
    谈小谈阅读 1,351评论 0 0
  • 昨天下午上了一堂非常烧脑的语言逻辑训练课,这堂课主要讲了四个方面。第一方面:演绎逻辑话术分解。第二个方面:论证方程...
    优乐维儿阅读 4,645评论 0 0

友情链接更多精彩内容