博客
关于我
js的new关键字
阅读量:206 次
发布时间:2019-02-28

本文共 970 字,大约阅读时间需要 3 分钟。

new关键字的作用

通过new关键字实例化构造函数,获取对象。

在JavaScript中,new关键字用于创建一个对象,这个对象是通过调用构造函数实现的。构造函数执行后,会返回一个新的对象,这个对象会继承构造函数原型链上的属性和方法。

以下是一个简单的示例:

<script> function Person(name) { this.name = name; this.say = function() { console.log(this.name); } } Person.prototype.age = '18'; Person.prototype.sayYes = function() { console.log('yyy'); } </script>
let p = new Person('小明'); console.log(p);

通过new关键字实例化的对象p,具备了构造函数Person中this的属性:name,也具备了构造函数Person的原型prototype的属性age和方法sayYes。

实现过程

当使用new关键字调用构造函数时,JavaScript会执行以下步骤:

  • 创建一个空对象,并且this变量引用该对象,同时还继承了该函数的原型。
  • 原型的属性和方法被加入到this引用的对象中。原型的执行,确定对象obj的原型链。
  • 新创建的对象由this所引用,并且最后隐士的返回this。绑定this对象为obj,传入参数;执行person构造函数,进行属性和方法的赋值操作。
  • 返回结果。注意:在通过该种方式获取对象时,最终不一定返回的是对象o,要看构造函数的返回值是什么。如果函数返回的是基本类型值,实际会生成一个对象,返回o。如果是函数返回的是引用类型值,则实际返回的是该引用类型值。

  • 例如,以下代码展示了通过new关键字实例化对象的过程:

    var obj = {}; obj.__proto__ = Person.prototype; person.call(obj, '小明');

    在这个过程中,obj会被作为this对象绑定,并传入参数'小明'执行person构造函数。执行后,person.call返回的结果是obj,即为new关键字创建的对象p。该对象会具备Person构造函数赋予的属性和方法。

    转载地址:http://iycp.baihongyu.com/

    你可能感兴趣的文章
    nowcoder—Beauty of Trees
    查看>>
    np.arange()和np.linspace()绘制logistic回归图像时得到不同的结果?
    查看>>
    np.power的使用
    查看>>
    NPM 2FA双重认证的设置方法
    查看>>
    npm build报错Cannot find module ‘webpack/lib/rules/BasicEffectRulePlugin‘解决方法
    查看>>
    npm build报错Cannot find module ‘webpack‘解决方法
    查看>>
    npm ERR! ERESOLVE could not resolve报错
    查看>>
    npm ERR! fatal: unable to connect to github.com:
    查看>>
    npm ERR! Unexpected end of JSON input while parsing near '...on":"0.10.3","direc to'
    查看>>
    npm ERR! Unexpected end of JSON input while parsing near ‘...“:“^1.2.0“,“vue-html-‘ npm ERR! A comp
    查看>>
    npm error Missing script: “server“npm errornpm error Did you mean this?npm error npm run serve
    查看>>
    npm error MSB3428: 未能加载 Visual C++ 组件“VCBuild.exe”。要解决此问题,1) 安装
    查看>>
    npm install CERT_HAS_EXPIRED解决方法
    查看>>
    npm install digital envelope routines::unsupported解决方法
    查看>>
    npm install 卡着不动的解决方法
    查看>>
    npm install 报错 EEXIST File exists 的解决方法
    查看>>
    npm install 报错 ERR_SOCKET_TIMEOUT 的解决方法
    查看>>
    npm install 报错 Failed to connect to github.com port 443 的解决方法
    查看>>
    npm install 报错 fatal: unable to connect to github.com 的解决方法
    查看>>
    npm install 报错 no such file or directory 的解决方法
    查看>>