Search

与我们合作

我们专注:网站策划设计、网络多媒体传播、网站优化及网站营销、品牌策略与设计
主营业务:网站建设、移动端微信小程序开发、VI设计、网络运营、云产品·运维解决方案

有一个品牌项目想和我们谈谈吗?

您可以填写右边的表格,让我们了解您的项目需求,这是一个良好的开始,我们将会尽快与您取得联系。当然也欢迎您给我们写信或是打电话,让我们听到您的声音

您也可通过下列途径与我们取得联系:

地 址: 深圳.龙岗区大运软件小镇11栋3楼

电 话: 138 2888 4598 / 138 0880 9053

网 址: http://www.appvx.cn

快速提交您的需求 ↓

JavaScript中this关键字的深入分析说明

时间:2020-06-16 浏览:3014 编辑:深圳网站设计 来源:互联网

this关键字的定义

this是Javascript语言的一个关键字。

普通定义:当前发生事件的对象。

通俗定义:当前的方法属于谁。

全局作用域中的this

console.log(this); // Window全局对象

在浏览器中执行,将会得到一个全局的Window对象。

在浏览器中执行,将会得到一个全局的Window对象。

1、纯粹的函数直接调用

var x = 1;

function test(){

 this.x = 0;

}

test();

alert(x); //0

this作为全局对象Global调用,属于全局通用性。

2、作为对象的方法调用

function test(){

 alert(this.x);

}

var o = {}; //声明一个对象

o.x = 1; //给对象添加一个属性

o.m = test; //给对象添加一个方法

o.m(); // 1 调用方法,结果为1

当函数作为对象的方法被调用时,this指向当前调用该方法的对象。

3、作为构造函数调用

var x = 2;

function test(){

 this.x = 1;

}

var o = new test();

alert(o.x); //1

alert(x); //2

var x = 2;

全局对象中的属性x并没有被改变,此时this指向该构造函数创建的对象。

4、apply、call、bind调用

var x = 0;

function test(){

 alert(this.x);

}

var o = {}; //声明一个对象

o.x = 1; //给对象添加一个属性

o.m = test; //给对象添加一个方法

o.m.apply(); //0

o.m.apply(o); //1

o.m.call(); //0

o.m.call(o); //1

call和apply都是Function对象的方法,都可以用来动态改变this的指向,达成函数复用的目的。

两个方法的第一个参数就是this,不传参数默认为全局对象,传入参数表示当前传入的对象。

注意:两种调用方式产生的结果完全相同。如果你已经有一个数组,使用apply方法,只有一个单独的变量,则用call方法。

嵌套函数作用域中的this

var a = 1;

function test(){

 console.log(this.a); // 2

 var self = this;

 function test2(){

  console.log(self.a); // 2

 }

 test2();

}

var o = {}; //声明一个对象

o.a = 2; //给对象添加一个属性

o.m = test; //给对象添加一个方法

o.m();

嵌套函数中,为了防止this作用域的混乱使用,通常自定义一个变量用于存储this,然后在嵌套函数内部使用这个变量,如代码中的self。

网站建设动画.gif

本站文章均为深正网站建设摘自权威资料,书籍,或网络原创文章,如有版权纠纷或者违规问题,请即刻联系我们删除,我们欢迎您分享,引用和转载,但谢绝直接搬砖和抄袭!感谢...
GO 欣赏案例
查看经典案例
在线咨询
电话咨询
0755-36630177
返回顶部
在线咨询 获取报价 电话咨询
获取报价
您的称呼:

*

您的电话:

*

您的邮箱:

*

提交 重置
重要的事情,电话里聊

接通客服

不方便的时候线上咨询,在线等哦