千家信息网

JavaScript中this对象怎么使用

发表于:2025-01-28 作者:千家信息网编辑
千家信息网最后更新 2025年01月28日,这篇文章主要介绍"JavaScript中this对象怎么使用"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"JavaScript中this对象怎么使用"文章能帮
千家信息网最后更新 2025年01月28日JavaScript中this对象怎么使用

这篇文章主要介绍"JavaScript中this对象怎么使用"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"JavaScript中this对象怎么使用"文章能帮助大家解决问题。

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

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

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

全局函数

在全局环境中,this指向Window

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

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

对象方法

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

//例子2var 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, ...)

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

//例子5var 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的。请看:

//例子6var 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。

关于"JavaScript中this对象怎么使用"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。

对象 函数 例子 指向 全局 方法 箭头 环境 代码 外层 就是 知识 还是 面的 运行 也就是 原因 只是 情况 所在 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 建立的数据库vb怎么用 数据库窗体小计函数 腾讯虚拟服务器 软件开发交付缺陷率 学习专业软件开发真的好 深圳市云咨询网络技术公司 服务器主机叫什么端口 蜘点网络技术总监 东莞考试软件开发公司 江阴进口软件开发报价表 网络安全专业都学些什么 数据库管理电子书机械工业出版社 互联网+与科技创新心得体会 济宁市委网络安全和信息化办 厦门纵横网络技术有限公司 网络安全最简短绕口令 查看服务器的带宽 网络安全技术学习的正确方法 成都完美网络技术有限公司 重庆微信软件开发教程 网络安全手抄报2020曲老师 装u8和数据库冲突吗 连接本地数据库所用函数是 摩尔庄园手游在哪里看服务器 厦门纵横网络技术有限公司 涉密软件开发资质证 网络技术服务费包括哪些 抖音 软件开发APP 湖北宜昌市dns服务器云主机 淮安专业软件开发咨询报价
0