位置: 编程技术 - 正文

javascript this详细介绍(彻底弄懂js中的this指向)

编辑:rootadmin

推荐整理分享javascript this详细介绍(彻底弄懂js中的this指向),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js function(this),彻底弄懂js中的this指向,javascript的this用法,js中this的作用,如何理解javascript中的this,javascript的this用法,javascript的this用法,如何理解javascript中的this,内容如对您有帮助,希望把文章链接给更多的朋友!

this的值是在运行时确定的

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

1. 全局作用域中的this

在全局作用域中,this指向window对象。

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

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

2. 函数中的this

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

2.1 构造函数中的this

构造函数的this指向它所创建的对象,如:

javascript this详细介绍(彻底弄懂js中的this指向)

2.2 普通函数中的this

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

3. 对象中的this

对象中的this指向当前对象,如:

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

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

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

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

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

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

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

apply用法

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

标签: 彻底弄懂js中的this指向

本文链接地址:https://www.jiuchutong.com/biancheng/373590.html 转载请保留说明!

上一篇:浅谈js内置对象Math的属性和方法(推荐)(js内置对象方法有哪些)

下一篇:javascript cookie用法基础教程(概念,设置,读取及删除)(js中cookie)

  • 交所得税用计提吗
  • 小规模纳税人怎么变成一般纳税人
  • 长期待摊费用借贷方向表示什么
  • 如何在网上查询发票
  • 个人所得税核定征收税率表
  • 税金及附加包括个人所得税吗
  • 应税职工福利费在应纳税所得额里面吗
  • 转让旧房增值税计税依据
  • 异地提供建筑服务
  • 营改增后企业出售使用过的旧车
  • 合并重组案例
  • 发生应收账款如何入账可避税
  • 未开票收入怎么写分录
  • 个体户能不能去注销
  • 开具增值税专用发票证明
  • 个人申请税务局开技术服务发票如何收费
  • excel自动计算增值税
  • 销售不动产增值税计税依据
  • 新公司企业怎么注册
  • 找私人贴现怎么做账
  • 企业间拆借应收利息记哪个科目?
  • 第二年缴纳税控盘服务费入什么科目?
  • 借壳上市是什么意思?融资
  • 企业开票信息可以改吗
  • 非贸易企业代扣代缴增值税和附加税如何做账?
  • 折旧可以计入主体成本吗
  • 资不抵债从资产负债表上怎么看出来
  • 怎么在bios里设置usb开关
  • 商业一般纳税人辅导期截止时间
  • 代办营业执照费用税务编码是多少
  • php数组函数题目
  • 增值税返还政策
  • 睡莲怎样养
  • 微信php开发
  • vue.min.js 本地引入
  • 金税三期个税扣缴客户端
  • 如何在vue项目中禁止谷歌浏览器改变网页颜色
  • testdisk安装方法
  • 魔改是啥
  • 员工探亲证明怎么写
  • 自查补缴增值税附表一怎么填写
  • 11个点的是什么星座
  • 接待客人的场合
  • 小规模纳税人交通运输服务税率
  • 土地增值税是什么税种类型
  • 企业营改增税率是多少
  • 企业的应付职工薪酬属于流动负债
  • 火车票退票改签手续费
  • 库存商品发出计价测试
  • 发票的几种分类
  • 折扣怎么写会计分录
  • 资产负债表期初余额和期末余额
  • 结构性存款怎么计算收益
  • 财政登记证取消了吗
  • 用友t3财务通普及版如何开下年账
  • 进项发票超过期限不认证怎么办
  • 账面银行存款余额与实际余额不符
  • 财经网课 app
  • 无形资产减值准备是什么科目
  • mysql分表实践
  • mysql修改后立即查询
  • win7系统c盘太满了,如何清理
  • 64位win8怎么安装南天PR2E针式打印机驱动?
  • win7系统安装教程不用u盘
  • ubuntu网卡命令
  • gzip压缩慢
  • alg.exe是什么程序
  • linux怎么安装iso
  • linux批量处理文件
  • msedge.exe是什么
  • win10手写输入法怎么设置
  • videoleap怎么加音频
  • unity fixed update
  • jquery 动态添加元素
  • 税务局24小时人工服务电话
  • 上海社保三方协议
  • 合伙企业的税收较高
  • 公司注销报税怎么申报
  • 13%增值税发票怎么抵扣
  • 武汉车船使用税收费标准
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设