位置: 编程技术 - 正文

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)

  • 税盘维护费的账务处理
  • 母公司和子公司可以一起投标吗
  • 装修行业专票的税率是多少
  • 房产租赁增值税率是5%还是9%
  • 开发票需要填银行吗
  • 附加税减免税额不能大于本期应纳税额怎么办
  • 房地产开发企业土地增值税清算
  • 劳务费免税发票的政策规定
  • 2020年关于住房公积金的新规定
  • 招待用烟的会计处理
  • 补计提上一年度费用
  • 收入做多增值税怎么算
  • 工程类什么情况下可以三方询价
  • 出口不退税怎么做账
  • 一般纳税人开3个点的票不能抵扣进项
  • 设备租赁费发票
  • 政府规费可以做进项抵扣吗?
  • 资产处置损益和营业外收支的区别和联系
  • 增值税简易征收一览表
  • 工业产值怎么计算的 统计
  • 主营业务收入会计分录怎样写
  • 专用发票可以抵扣吗
  • 最新早上好图片大全集
  • 苹果x如何显示电量数字
  • macos monterey支持哪些显卡
  • 成本加成法的缺点
  • windows 10 版本 21h1
  • 在win7系统中将打开窗口拖到屏幕顶端
  • php面向对象是什么意思
  • mac osx10.11
  • 产品成本核算应正确划分哪些方面的费用界限
  • php数字增1
  • 【torch.nn.Parameter 】参数相关的介绍和使用
  • 天猫提现到对公账户怎么做账
  • django pypi
  • vscode插件大全
  • 转让企业要交什么税
  • node与nodejs
  • 个体户开普票有没有完税证明
  • 织梦商城网站源码
  • 残保金都要申报吗
  • 现金股利要交税
  • 运输行业油费怎么入账
  • 物业公司收取的电费怎么确认收入
  • 蓝字发票红字发票什么意思
  • 合并抵消分录影响母公司总分类账吗
  • 酒店客房收入会计分录
  • 线上线下财务
  • 广告费应归于什么费用
  • 红字发票的开具需要把开始的发票取回作废吗?
  • 公司购买电缆线怎么做账
  • 删除sql server2019
  • mysql中的where子句
  • sql server如何判断数据库是否存在
  • win8的文件夹选项在哪里
  • linux系统基本指令
  • win8.1系统升级win10
  • bios没有usb启动项解决方法联想
  • 传统与现代的结合英文
  • win10选择一个选项
  • win8系统开机
  • win10系统下如何打开internet(ISS)信息服务
  • linux中ftp
  • win8无法关机一直转圈
  • win8怎么启动资源管理器
  • win8的系统
  • js 原型链继承 原型式继承
  • 推荐10 个很棒的电影
  • Node.js中的construct构造函数
  • 滑动到点击位置的快捷键
  • linux生成网卡配置文件
  • css filter blur
  • 脚本控制三行三列怎么写
  • python简易
  • angular 创建项目
  • js中tolocalestring
  • 复印店开什么发票
  • 我国现行税率分
  • 小规模纳税人租赁收入增值税税率是多少
  • 山西收入最高的县
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设