new 一个对象的过程发生了什么

栏目: JavaScript · 发布时间: 4年前

内容简介:当你要创建某一个类的实例的时候,会用到new操作符。但是这个过程到底发生了什么呢?1、创建了一个新对象。(不知道可不可以解释为从堆内存里开辟了一块内存2、将构造函数的作用域赋值给了新对象,也就是说谁被new了,this就指向谁。

当你要创建某一个类的实例的时候,会用到new操作符。但是这个过程到底发生了什么呢?

1、创建了一个新对象。(不知道可不可以解释为从堆内存里开辟了一块内存

2、将构造函数的作用域赋值给了新对象,也就是说谁被new了,this就指向谁。

假设有一个类Person,创建它的实例louis

function Person(name){
    this.name = name
}
Person.prototype.sayName= function(){
    console.log(this.name)
}

let louis = new Person('louis') //此时的this指向louis
louis.sayName() //louis

3、执行了构造函数中的代码,也就是执行了上面Person里的代码

4、返回新对象 如果没有另外设置return的值即返回了louis,否则返回你重新设置的对象


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

CSS3 For Web Designers

CSS3 For Web Designers

Dan Cederholm / Happy Cog / 2010-11 / $18

From advanced selectors to generated content to the triumphant return of web fonts, and from gradients, shadows, and rounded corners to full-blown animations, CSS3 is a universe of creative possibilit......一起来看看 《CSS3 For Web Designers》 这本书的介绍吧!

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

html转js在线工具
html转js在线工具

html转js在线工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具