详解Javascript中new()到底做了些什么?

 更新时间:2018年03月29日 10:24:41   作者:一直在寻  
javascript中,new操作符的工作原理是什么?它是怎样改变构造函数的返回值和this指向的?下面这篇文章就来给大家介绍了关于Javascript中new()到底做了些什么的相关资料,需要的朋友可以参考下。

前言

和其他高级语言一样 javascript 中也有 new 运算符,我们知道 new 运算符是用来实例化一个类,从而在内存中分配一个实例对象。 但在 javascript 中,万物皆对象,为什么还要通过 new 来产生对象? 本文将带你一起来探索 javascript 中 new 的奥秘...

要创建 Person 的新实例,必须使用 new 操作符。

以这种方式调用构造函数实际上会经历以下 4个步骤:

(1) 创建一个新对象;

(2) 将构造函数的作用域赋给新对象(因此 this 就指向了这个新对象) ;

(3) 执行构造函数中的代码(为这个新对象添加属性) ;

(4) 返回新对象。

 new 操作符

在有上面的基础概念的介绍之后,在加上new操作符,我们就能完成传统面向对象的class + new的方式创建对象,在JavaScript中,我们将这类方式成为Pseudoclassical。

基于上面的例子,我们执行如下代码

var obj = new Base();

这样代码的结果是什么,我们在Javascript引擎中看到的对象模型是:


new操作符具体干了什么呢?其实很简单,就干了三件事情。

var obj = {};
obj.__proto__ = Base.prototype;
Base.call(obj);

第一行,我们创建了一个空对象obj

第二行,我们将这个空对象的__proto__成员指向了Base函数对象prototype成员对象

第三行,我们将Base函数对象的this指针替换成obj,然后再调用Base函数,于是我们就给obj对象赋值了一个id成员变量,这个成员变量的值是”base”,关于call函数的用法。

如果我们给Base.prototype的对象添加一些函数会有什么效果呢?

例如代码如下:

Base.prototype.toString = function() {
 return this.id;
}

那么当我们使用new创建一个新对象的时候,根据__proto__的特性,toString这个方法也可以做新对象的方法被访问到。于是我们看到了:

构造子中,我们来设置‘类'的成员变量(例如:例子中的id),构造子对象prototype中我们来设置‘类'的公共方法。于是通过函数对象和Javascript特有的__proto__与prototype成员及new操作符,模拟出类和类实例化的效果。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

相关文章

  • 在javascript将NodeList作为Array数组处理的方法

    在javascript将NodeList作为Array数组处理的方法

    在Web前端编程中,我们通常会通过document.getElementsByTagName的方法取出一组相同标签的dom元素。
    2010-07-07
  • underscore 防抖技巧学习示例

    underscore 防抖技巧学习示例

    这篇文章主要为大家介绍了underscore 防抖技巧学习示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • echarts实现折线图的拖拽效果

    echarts实现折线图的拖拽效果

    这篇文章主要为大家详细介绍了echarts实现折线图的拖拽效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • Iframe自适应高度绝对好使的代码 兼容IE,遨游,火狐

    Iframe自适应高度绝对好使的代码 兼容IE,遨游,火狐

    Iframe自适应高度绝对好使的代码IE,遨游,火狐都兼容,需要的朋友可以参考下。
    2011-01-01
  • JavaScript之Blob对象类型的具体使用方法

    JavaScript之Blob对象类型的具体使用方法

    这篇文章主要介绍了JavaScript之Blob对象类型的具体使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • artdialog的图片/标题以及关闭按钮不显示的解决方法

    artdialog的图片/标题以及关闭按钮不显示的解决方法

    正如标题所言不显示的原因是因其它css样式文件中包含div{ overflow:hidden; }引起的artdialog的图片以及关闭按钮不显示,具体的解决方法如下,感兴趣的朋友可以参考下哈
    2013-06-06
  • Javascript的表单验证-提交表单

    Javascript的表单验证-提交表单

    JavaScript 可用来在数据被送往服务器前对 HTML 表单中的这些输入数据进行验证。通过本文给大家介绍Javascript的表单验证-提交表单,对javascript表单验证,提交表单相关知识感兴趣的朋友一起学习吧
    2016-03-03
  • javascript web页面刷新的方法收集

    javascript web页面刷新的方法收集

    javascript refresh page,页面刷新实现代码。
    2009-07-07
  • JS小数转换为整数的方法分析

    JS小数转换为整数的方法分析

    这篇文章主要介绍了JS小数转换为整数的方法,结合实例形式分析了数值转换的常用方法与使用技巧,需要的朋友可以参考下
    2017-01-01
  • javascript入门基础之私有变量

    javascript入门基础之私有变量

    开始接触这门语言时,可能都会觉得这门语言缺少访问控制符(如public、private、protected),从而导致不能定义私有变量和私有方法。但经过进一步了解就会知道javascript同样可以有私有变量。
    2010-02-02

最新评论