博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS 中 this上下文对象的使用方式
阅读量:4085 次
发布时间:2019-05-25

本文共 2690 字,大约阅读时间需要 8 分钟。

JavaScript 有一套完全不同于其它语言的对 this 的处理机制。 在五种不同的情况下 ,this 指向的各不相同。

有句话说得很在理 -- 谁调用它,this就指向谁

http://www.cnblogs.com/imwtr/p/4766543.html

 

一、全局范围内

在全局范围内使用this ,它将指向全局对象(浏览器中为 window)

var name = 'name1';console.log(name);this.name = 'name2';console.log(name);console.log(this.name);window.name = 'name3';console.log(name);console.log(this.name);console.log(window.name);

 

二、函数调用

直接调用一个函数,this 默认会指向全局 (浏览器端为window)

var name = 'name1';function sayName(){    console.log(name);    console.log(this);}sayName();window.sayName();

可以看到

还有几个常见的情况,根据谁调用方法就指向谁的原则,this的指向要细看

// 全局 namevar name = 'name1';var obj = {    name: 'name2',    sayName: function(){                // 调用它的时候 this指向全局        return function(){            console.log(this.name);        };    },    changeName: function(){               // 调用它的时候 this指向全局        setTimeout(function(){            this.name = 'name3';        },0);    }};obj.sayName()();obj.changeName();setTimeout(function(){    console.log(name);    console.log(obj.name);},0);

像这些类似匿名的函数,默认都是被全局(浏览器下的window)对象调用,要正确地让obj调用,就要指代好

可以用that保持this再进行下一步,或者匿名函数传值,或者使用call/apply/bind改变context等

var name = 'name1';var obj = {    name: 'name2',    sayName: function(){        var that = this;        return function(){            console.log(that.name);        };    },    changeName: function(){        var that = this;        setTimeout(function(){            that.name = 'name3';        },0);    }};obj.sayName()();  // name2obj.changeName();setTimeout(function(){    console.log(name); // name1    console.log(obj.name);  // name3},0);

 

三、作为对象方法的调用

其实就类似上头提到的 obj.sayName()  obj.name 等

这时this会指向这个obj

 

四、call/apply/bind 的调用

当使用 Function.prototype 上的 call 或者 apply ,bind 方法时,函数内的 this将会被 显式设置为函数调用的第一个参数。

我们可以稍微修改一下上头的代码,就可以看到this指向的改变

var name = 'name1';var obj = {    name: 'name2',    sayName: function(){        // 返回一个默认全局的函数        return function(){            console.log(this.name);        };    },    changeName: function(){        // 返回一个默认全局的函数        setTimeout(function(){            this.name = 'name3';        // 然后将该函数绑定给this(当前obj对象)        }.bind(this),0);    }};// obj.sayName()这个函数,让obj来调用obj.sayName().call(obj);//  让this(也就是全局对象)来调用obj.sayName().apply(this);obj.changeName();setTimeout(function(){    // 输出更改之后,全局name的值    console.log(name);    // 输出更改之后,obj对象中 name的值    console.log(obj.name);},0);

 

五、作为构造函数调用

比如 new Foo();

先来看个简单的例子:

var name = 'name1';function Foo(){    // 赋值this(当前对象)的name属性值    this.name = 'name2';}// new 构造函数产生一个实例var foo = new Foo();console.log(name);console.log(foo.name);// 直接调用该函数Foo();console.log(name);

可以看到,如果函数倾向于和 new 关键词一块使用,则我们称这个函数为构造函数,当new 了之后,this则指向这个心创建的对象(这个new 的过程其实也涉及到了继承机制)。

若直接调用这个函数,this就默认执行全局对象了。

 

你可能感兴趣的文章
my read_university
查看>>
network manager
查看>>
OS + Linux Disk disk lvm / disk partition / disk mount / disk io
查看>>
RedHat + OS CPU、MEM、DISK
查看>>
net TCP/IP / TIME_WAIT / tcpip / iperf / cain
查看>>
webServer kzserver/1.0.0
查看>>
OS + Unix IBM Aix basic / topas / nmon / filemon / vmstat / iostat / sysstat/sar
查看>>
my ReadMap subway / metro / map / ditie / gaotie / traffic / jiaotong
查看>>
OS + Linux DNS Server Bind
查看>>
linux下安装django
查看>>
Android 解决TextView设置文本和富文本SpannableString自动换行留空白问题
查看>>
Android开发中Button按钮绑定监听器的方式完全解析
查看>>
Android自定义View实现商品评价星星评分控件
查看>>
postgresql监控工具pgstatspack的安装及使用
查看>>
postgresql查看表的和索引的情况,判断是否膨胀
查看>>
postgresql中根据oid和filenode去找表的物理文件的位置
查看>>
postgresql减少wal日志生成量的方法
查看>>
swift中单例的创建及销毁
查看>>
获取App Store中App的ipa包
查看>>
iOS 关于pods-frameworks.sh:permission denied报错的解决
查看>>