php this精讲,javascript this详细讲解(图文教程)

这篇文章主要介绍了javascript this详细介绍的相关资料,需要的朋友可以参考下

this的值是在运行时确定的

JS中的this究竟代表什么,这是在程序运行时根据上下文环境确定,可以分为以下几种情况。

1. 全局作用域中的this

在全局作用域中,this指向window对象。console.log(this);//指向window对象

this.x = 5//在全局作用域内创建一个x

//与this.x = 5的等价情况:

//var x = 5;

//x = 5;

在全局作用域中执行var x=5,其实是为window对象创建一个属性x,并令其等于5。

若定义变量时不加var,JS会认为该变量为全局变量,会将其当作window对象的属性。

2. 函数中的this

JS中函数有两种,直接调用的函数称为普通函数,通过new创建对象的函数称为构造函数。

2.1 构造函数中的this

构造函数的this指向它所创建的对象,如:function Person(name){

this.name = name;//this指向该函数创建的对象person

}

var person = new Person("chaimm");

2.2 普通函数中的this

普通函数的this指向window对象。

若上述例子,直接执行Perosn函数,则其中this代表window对象,因此该函数执行后会创建一个全局的name。function Person(name){

this.name = name;//this指向window

}

Person("chai");//当作普通函数执行,this指向window对象

3. 对象中的this

对象中的this指向当前对象,如:var person = {

name : "chaimm",

getName : function(){

return this.name;

}

}

上述代码中this指向函数getName所属的对象。

但是,如果一个对象的函数中又嵌套了一个函数,这个函数的this指向的却是window,而并不是其外层的对象。var person = {

name : "chaimm",

setName : function(name){

(function(name){

this.name = name; //此时this并不代表person对象,而是代表window对象

})(name);

}

}

上述示例中,person对象中有一个getName函数,而getName函数内部又有一个函数,这个函数内部的this指向window对象,而非person对象,这是JS的一个bug!一般作如下处理,规避这个bug:var person = {

name : "chaimm",

setName : function(name){

var thar = this;//将this赋给that

(function(name){

that.name = name;//此时that指向person对象

})(name);

}

}

我们在person对象的第一层函数中,将this赋给局部变量that,然后在第二层函数中使用that,此时that指向person对象,可对person的属性进行操作。

注意:若将一个对象中的函数赋给一个变量后,再通过该变量调用这个函数,此时该函数中的this指向window,而非该对象,如下所示:var person = {

name : "chaimm",

getName : function(){

return this.name;

}

}

//将getName函数赋给一个新的变量

var newGetName = person.getName;

//通过新的变量调用这个函数,这个函数中的this将指向window

newGetName();//若全局作用域中没有name,则将返回undefined

4. 用call和apply函数给this开挂

这两个函数都能手动指定被调用函数内部的this指向哪个对象。//定义一个构造函数

var Person = function(name){

this.name = "";

this.setName = function(name){

this.name = name;

}

}

//创建两个对象

var personA = new Person("A");

var personB = new Person("B");

//使用personA的setName函数去修改personB的name属性

personA.setName.apply(personB,["C"]);

apply用法

对象A.函数名.apply(对象B, 参数列表);

当对象B作为apply的第一个参数传给apply时,对象A的函数中this就指向了对象B,此时对象A的该函数对this的操作将会作用在对象B上,由此实现了用对象A去调用对象B的函数。

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值