js中this对象用法分析


Posted in Javascript onJanuary 05, 2018

this对象是在函数运行时,基于函数的执行环境绑定的。

其实这句话的本质就是,谁调用了函数,this就指向谁

具体的来说,通常有以下几种情况:

全局函数

在全局环境中,this指向Window

//例子1
 function A() {
 console.log(this)
 }
 A();//Window

上面的例子很简单,函数A在全局环境中执行,也就是全局对象Window调用了函数。此时this指向Window

对象方法

作为对象方法调用时,this指向调用该方法的对象

//例子2
var b = {
 getThis:function(){
  console.log(this)
 }
}
b.getThis()//b

到这里我们举的例子都比较简单易懂,接下来来一个有意思的:

//例子3
 var c = {
 getFunc:function(){
  return function(){
  console.log(this)
  }
 }
 }
 var cFun = c.getFunc()
 cFun()//Window

这个例子和前一个例子不一样,运行c.getFunc()时,首先返回的是一个匿名函数,我们将这个函数赋值给cFun,接着在全局环境中调用了cFun(),所以此时this指向的还是Window。

如果我们一定要让这里返回的是c对象呢?在开头我们说过,this对象是在函数执行时确定的,在例子3中,执行c.getFunc()时,this对象指向的还是c,所以我们只要保持住这个this就好了,对上面的代码稍微改动:

//例子4
 var c = {
 getFunc:function(){
  var that = this //在这里保留住this
  return function(){
  console.log(that)
  }
 }
 }
 var cFun = c.getFunc()
 cFun()//c

这也就是我们经常可以在一些代码中看到var self = this或者var that = this之类的原因了。

call和apply

此时this对象通常指向函数中指定的this值(注意这里的通常2字,考试要考的)

call和apply算是老生常谈,但还是稍微介绍下,怕新同学可能没接触过(其实是为了凑点字数),拿call来说,语法是这样的

fun.call(thisArg, arg1, arg2, ...)

这个方法怎么用呢,看下面的例子:

//例子5
var d = {
 getThis:function(){
  console.log(this)
 }
}
var e = {
 name:'e'//(给e写个`name`属性只是因为觉得孤零零的太难看了~~)
}
d.getThis.call(e)//e

在这里我们就可以看出call函数的意思了:指定一个对象o1去调用其他对象o2的方法,此时this对象指向o1

好了,那为什么前面我们说通常呢?因为,这里的thisArg是可以指定为null和undefined的。请看:

//例子6
var d = {
 getThis:function(){
  console.log(this)
 }
}
 d.getThis.call(null)//Window
 d.getThis.call(undefined)//Window

此时的this指向全局对象Window

箭头函数

es6中的箭头函数现在也用的比较频繁,但是有个需要注意的点是:

函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。

其实出现这种情况的根本原因是:箭头函数没有this对象,所以箭头函数的this就是外层代码的this

//例子7
 var f = {
  getThis:()=>{
   console.log(this)
  }
 }
 f.getThis()//Window

这个例子和前面例子2是基本一样的,只是把普通函数改写成箭头函数,但是此时的this对象已经指向了外层的Window。

考虑到这一点可能不好理解,我们再看几个例子:

//例子8
 var g = {
 getThis:function(){
  return function(){console.log(this)}
 }
 }
 var h = {
 getThis:function(){
  return ()=> console.log(this)
 }
 }
 g.getThis()()//Window
 h.getThis()()//h

这个例子里,g的getThis写法就和之前的例子3一样,由于函数在全局环境中运行,所以此时this指向Window;h的getThis使用了箭头函数,所以this指向了外层代码块的this所以,此时this指向的是h。

总结

一般情况下this对象指向调用函数的对象,全局环境中执行函数this对象指向Window

在call和apply函数中this指向指定的对象,如果指定的对为undefined或者null,那么this对象指向Window

在箭头函数中,this对象等同于外层代码块的this

然后依然是每次都一样的结尾,如果内容有错误的地方欢迎指出;如果对你有帮助,欢迎点赞和收藏,感谢你对三水点靠木的支持。

Javascript 相关文章推荐
多个iframe自动调整大小的问题
Sep 18 Javascript
Jquery ajax传递复杂参数给WebService的实现代码
Aug 08 Javascript
Dom 学习总结以及实例的使用介绍
Apr 24 Javascript
如何设置iframe高度自适应在跨域情况下的可用方法
Sep 06 Javascript
jquery动态改变div宽度和高度
Feb 09 Javascript
基于socket.io+express实现多房间聊天
Mar 17 Javascript
分离与继承的思想实现图片上传后的预览功能:ImageUploadView
Apr 07 Javascript
jquery 获取select数组与name数组长度的实现代码
Jun 20 Javascript
如何用js判断dom是否有存在某class的值
Feb 13 Javascript
Vue中util的工具函数实例详解
Jul 08 Javascript
解决Vue中使用keepAlive不缓存问题
Aug 04 Javascript
关于Javascript闭包与应用的详解
Apr 22 Javascript
Node中使用ES6语法的基础教程
Jan 05 #Javascript
解决JSON.stringify()自动将中文转译成unicode的问题
Jan 05 #Javascript
vue脚手架中配置Sass的方法
Jan 04 #Javascript
Angular4学习教程之HTML属性绑定的方法
Jan 04 #Javascript
JS基于for语句编写的九九乘法表示例
Jan 04 #Javascript
JS计算输出100元钱买100只鸡问题的解决方法
Jan 04 #Javascript
Angular4学习教程之DOM属性绑定详解
Jan 04 #Javascript
You might like
Nginx下配置codeigniter框架方法
2015/04/07 PHP
PHP 实现页面静态化的几种方法
2017/07/23 PHP
关于laravel 数据库迁移中integer类型是无法指定长度的问题
2019/10/09 PHP
PHP实现简单用户登录界面
2019/10/23 PHP
Ext.FormPanel 提交和 Ext.Ajax.request 异步提交函数的区别
2009/11/12 Javascript
基于jQuery的星级评分插件
2011/08/12 Javascript
Bootstrap项目实战之首页内容介绍(全)
2016/04/25 Javascript
第九篇Bootstrap导航菜单创建步骤详解
2016/06/21 Javascript
jQuery使用serialize()表单序列化时出现中文乱码问题的解决办法
2016/07/27 Javascript
浅谈jquery上下滑动的注意事项
2016/10/13 Javascript
vue.js将unix时间戳转换为自定义时间格式
2017/01/03 Javascript
Cookies 和 Session的详解及区别
2017/04/21 Javascript
bootstrap table单元格新增行并编辑
2017/05/19 Javascript
使用jQuery.Pin垂直滚动时固定导航
2017/05/24 jQuery
jQuery滚动条美化插件nicescroll简单用法示例
2018/04/18 jQuery
利用d3.js实现蜂巢图表带动画效果
2019/09/03 Javascript
如何在wxml中直接写js代码(wxs)
2019/11/14 Javascript
vue实现移动端图片上传功能
2019/12/23 Javascript
javascript设计模式 ? 装饰模式原理与应用实例分析
2020/04/14 Javascript
[53:10]2018DOTA2亚洲邀请赛 4.6 淘汰赛 VP vs VG 第一场
2018/04/11 DOTA
[48:26]VGJ.S vs infamous Supermajor 败者组 BO3 第二场 6.4
2018/06/05 DOTA
python之wxPython应用实例
2014/09/28 Python
Python中比较特别的除法运算和幂运算介绍
2015/04/05 Python
Python多线程结合队列下载百度音乐的方法
2015/07/27 Python
浅谈Python 字符串格式化输出(format/printf)
2016/07/21 Python
python中urllib.unquote乱码的原因与解决方法
2017/04/24 Python
Python tkinter label 更新方法
2018/10/11 Python
Django model update的多种用法介绍
2020/03/28 Python
python如何通过闭包实现计算器的功能
2020/02/22 Python
python GUI库图形界面开发之PyQt5计数器控件QSpinBox详细使用方法与实例
2020/02/28 Python
Python读取xlsx数据生成图标代码实例
2020/08/12 Python
Python 实现国产SM3加密算法的示例代码
2020/09/21 Python
scrapy结合selenium解析动态页面的实现
2020/09/28 Python
篮球兴趣小组活动总结
2014/07/07 职场文书
施工安全协议书范本
2014/09/26 职场文书
2015年七七事变78周年纪念活动方案
2015/05/06 职场文书