obj.属性; 调用属性
obj.方法(); 调用方法
③注意事项
>>>通过类名,new出一个对象的过程,叫做“类的实例化”
>>>类中的this,会在实例化的时候,指向新new出的对象。所以,this.属性 this.方法,实际上是将属性和方法绑定在即将new出的对象上面。
>>>在类中,要调用自身属性,必须使用this.属性名、如果直接使用变量名,则无法访问对应的属性。
>>>类名必须使用大驼峰法则,注意与普通函数的区别。
2.2两个重要属性constructor和instanceof
①constructor:返回当前对象的构造函数
>>>zhangsan.constructor = Person; √
②instanceof:检测一个对象,是不是一个类的实例;
>>>lisi instanceof Person √ lisi是通过Person类new出的
>>>lisi instanceof Object √ 所有对象都是Object的实例
>>>Person instanceof Object √ 函数本身也是对象
3、 JavaScript中的this指向问题
在上一部分中,我们创建了一个类,并通过这个类new出了一个对象。 但是,这里面出现了大量的this。 很多同学就要懵逼了,this不是“这个”的意思吗?为什么我在函数里面写的this定义的属性,最后到了函数new出的对象呢??
3.1谁最终调用函数,this就指向谁!
① this指向谁,不应该考虑函数在哪声明,而应该考虑函数在哪调用!!
② this指向的,永远只可能是对象,不可能是函数!!
③ this指向的对象,叫做函数的上下文context,也叫函数的调用者。
3.2this指向的规律(与函数的调用方式息息相关!)
① 通过函数名()调用的,this永远指向window
func(); // this--->window //【解释】 我们直接用一个函数名()调用,函数里面的this,永远指向window。
② 通过对象.方法调用的,this指向这个对象
// 狭义对象 var obj = { name:"obj", func1 :func }; obj.func1(); // this--->obj //【解释】我们将func函数名,当做了obj这个对象的一个方法,然后使用对象名.方法名, 这时候函数里面的this指向这个obj对象。 // 广义对象 document.getElementById("div").onclick = function(){ this.style.backgroundColor = "red"; }; // this--->div //【解释】对象打点调用还有一个情况,我们使用getElementById取到一个div控件,也是一种广义的对象,用它打点调用函数,则函数中的this指向这个div对象。
③ 函数作为数组的一个元素,用数组下标调用,this指向这个数组
var arr = [func,1,2,3]; arr[0](); // this--->arr //【解释】这个,我们把函数名,当做数组中的一个元素。使用数组下标调用,则函数中的this将指向这个数组arr。
内容版权声明:除非注明,否则皆为本站原创文章。