位置: 编程技术 - 正文

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中链接图片对方能显示
  • 已收款未发货会计分录
  • 银行存款日期和起息日期不一样
  • type3插件
  • 什么是递延所得税资产和负债
  • 在windows7操作具有
  • php自学
  • 企业通讯费管理办法
  • 司法拍卖所购的房产
  • 公司员工的车加油可以开公司发票吗
  • element ui停止
  • 基于Java+SpringBoot+Vue前后端分离仓库管理系统设计实现
  • nerf代码
  • ChatGPT中国电话不能注册
  • netconf over ssh
  • 买商品赠送赠品怎么做账
  • 机动车发票哪几联 做帐
  • 参展费可以抵扣吗
  • 民间非营利组织会计制度
  • 专家咨询费比例不能超过多少
  • 劳务费发票为什么必须每月开
  • mongodb从入门到商业实战
  • 主营业务成本应交税费
  • 农机销售融资贷款流程
  • 一般纳税企业增值税的核算应当使用
  • 交通运输企业有什么优惠政策
  • 个体工商户怎么开发票
  • 怎样计算主营业务收入
  • 怎么处理部分股票流出
  • 安装调试费属于劳务还是服务
  • 预缴的增值税及附加税怎么做账
  • 先收款次月发票怎么做账
  • 为什么工程施工图纸不能泄露
  • 未缴纳或未足额缴纳出资的股东
  • 购买天然气进项税额
  • 公司购买的车辆
  • 汽车费用包括哪些会计科目呢
  • 房地产企业会计科目
  • ubuntu常用操作
  • Mac苹果系统怎么转换中文
  • 常见unix操作系统
  • fragment懒加载原理
  • android ui绘制
  • nodejs常用api
  • nodejsapi框架
  • linux命令shell脚本
  • 用批处理删除注册表项
  • jquery的使用方法
  • 深入理解python特性
  • 三消游戏在线
  • javascript scrollLeft,scrollWidth,clientWidth,offsetWidth 完全详解
  • jquery实现自动轮播
  • bootstrap layer弹框
  • 在css中
  • js实现dialog
  • 关于明确干部挂职工作期间有关待遇的
  • 定额发票是什么票据类型
  • 按时交纳党费
  • 办理跨区域事项报验
  • 重庆国税电子税务局
  • 超期未申报还能申报吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设