博客
关于我
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/

    你可能感兴趣的文章
    NSError 的使用方法
    查看>>
    nsis 安装脚本示例(转)
    查看>>
    NSJSON的用法(oc系统自带的解析方法)
    查看>>
    nslookup 的基本知识与命令详解
    查看>>
    NSOperation基本操作
    查看>>
    NSRange 范围
    查看>>
    NSSet集合 无序的 不能重复的
    查看>>
    NSURLSession下载和断点续传
    查看>>
    NSUserdefault读书笔记
    查看>>
    NS图绘制工具推荐
    查看>>
    NT AUTHORITY\NETWORK SERVICE 权限问题
    查看>>
    NT symbols are incorrect, please fix symbols
    查看>>
    ntelliJ IDEA 报错:找不到包或者找不到符号
    查看>>
    NTFS文件权限管理实战
    查看>>
    ntko web firefox跨浏览器插件_深度比较:2019年6个最好的跨浏览器测试工具
    查看>>
    ntko文件存取错误_苹果推送 macOS 10.15.4:iCloud 云盘文件夹共享终于来了
    查看>>
    ntp server 用法小结
    查看>>
    ntpdate 通过外网同步时间
    查看>>
    ntpdate同步配置文件调整详解
    查看>>
    NTPD使用/etc/ntp.conf配置时钟同步详解
    查看>>