js中new一个对象的过程

 更新时间:2017年02月20日 10:44:54   作者:开发之路  
本文主要介绍了js中new一个对象的过程。具有很好的参考价值,下面跟着小编一起来看下吧

使用new关键字调用函数(new ClassA(…))的具体步骤:

1. 创建空对象{}

2. 使用新对象,调用函数,函数中的this被指向新实例对象:

         {}.构造函数();         

3. 设置新对象的constructor属性为构造函数的名称,设置新对象的__proto__属性指向构造函数的prototype对象

4. 将初始化完毕的新对象地址,保存到等号左边的变量中

注意:若构造函数中没有返回值或返回值是基本类型(Number、String、Boolean)的值,则返回新实例对象;若返回值是引用类型的值,则实际返回值为这个引用类型。

var foo = "bar";
function test () {
 this.foo = "foo";
}
new test();          //test中的this指新对象,并未改变全局的foo属性
console.log(this.foo);  // "bar"
console.log(new testThis().foo); // "foo";new和属性访问.运算符优先级相通,从左往右执行

以上皆为个人理解,如有错误之处,欢迎留言指正。

希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

相关文章

  • JavaScript实现的SHA-1加密算法完整实例

    JavaScript实现的SHA-1加密算法完整实例

    这篇文章主要介绍了JavaScript实现的SHA-1加密算法,以完整实例形式分析了SHA-1加密算法的具体实现技巧,需要的朋友可以参考下
    2016-02-02
  • javascript数组中的reduce方法和pop方法

    javascript数组中的reduce方法和pop方法

    这篇文章主要介绍了javascript数组中的reduce方法和pop方法,文章内容介绍详细,具有一定的参考价值需要的小伙伴可以参考一下,希望对你的学习有所帮助
    2022-03-03
  • JS闭包与延迟求值用法示例

    JS闭包与延迟求值用法示例

    这篇文章主要介绍了JS闭包与延迟求值,结合简单实例分析了JS针对运算量较大的情况下闭包与延迟求值的实现技巧,需要的朋友可以参考下
    2016-12-12
  • Three.js PBR物理渲染属性及使用介绍

    Three.js PBR物理渲染属性及使用介绍

    这篇文章主要为大家介绍了Three.js PBR物理渲染属性及使用介绍,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • JavaScript深入理解系列之call与apply

    JavaScript深入理解系列之call与apply

    Function.prototype.call和Function.prototype.apply都是非常常用的方法,它们的作用一模一样,区别仅在于传入参数形式的不同,下面这篇文章主要介绍了JavaScript深入理解系列之call与apply的相关资料,需要的朋友可以参考下
    2022-04-04
  • 基于JavaScript实现单例模式

    基于JavaScript实现单例模式

    这篇文章主要介绍了基于JavaScript实现单例模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • js实现统计字符串中特定字符出现个数的方法

    js实现统计字符串中特定字符出现个数的方法

    这篇文章主要介绍了js实现统计字符串中特定字符出现个数的方法,涉及javascript针对字符串中字符运算操作相关技巧,需要的朋友可以参考下
    2016-08-08
  • JS几个常用的函数和对象定义与用法示例

    JS几个常用的函数和对象定义与用法示例

    这篇文章主要介绍了JS几个常用的函数和对象定义与用法,涉及JavaScript日期时间、数值计算及变量判断等相关操作技巧,需要的朋友可以参考下
    2020-01-01
  • js如何实现设计模式中的模板方法

    js如何实现设计模式中的模板方法

    都知道在js中如果定义两个相同名称的方法,前一个方法就会被后一个方法覆盖掉,使用此特点就可以实现模板方法,感兴趣的朋友可以了解下本文哈
    2013-07-07
  • addeventlistener监听scroll跟touch(实例讲解)

    addeventlistener监听scroll跟touch(实例讲解)

    下面小编就为大家带来一篇addeventlistener监听scroll跟touch(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08

最新评论