位置: 编程技术 - 正文

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)

  • 私车公用如何处理
  • 个人去税务局开劳务费怎么交税
  • 应交税费会计分录怎么做明细科目
  • 税法规定的增值税
  • 维修费开具发票
  • 建筑业工程结算是什么科目
  • 小微企业税务服务站
  • 一般纳税人小微企业印花税优惠政策
  • 残保金申报在哪申报
  • 行政单位利息收入是非税收入吗
  • 增值税普通发票怎么开
  • 劳务报酬所得是什么
  • 建筑企业预缴印花税会计分录
  • 做税审报告费如何做分录?
  • 服务业发票丢失怎么处理
  • 非营利机构收到专用发票
  • 应收账款减值处理
  • 无偿代建政府公告
  • 文具代销
  • 信用等级D可以贷款吗
  • 社保滞纳金税前怎么算
  • 银行代发工资当月没发下个月发没事儿吧
  • 独立核算分公司可以享受小型微利企业优惠吗
  • 地税退税怎么做分录
  • 固定资产累计折旧借方表示什么
  • 事业单位固定资产盘盈账务处理
  • 进项税额加计抵减怎么做分录
  • win11家庭版怎么激活
  • 企业所得税季度申报表季度平均值
  • 企业为开发新产品新技术新工艺
  • 进项税和销项税怎么理解
  • php utf8转gb2312
  • scm wms
  • 先开票后收款的发票怎么备注
  • 鼠标按键多有用吗
  • 多开发票可以作废吗?
  • framework core
  • 简述gnss数据处理流程
  • yii2-admin
  • 雷斯岬国家海岸公园有信号吗
  • php删除txt指定内容
  • hive dt
  • mongodb4.4安装
  • 专项应付款能转出来吗
  • 企业坏账准备提取的方法和提取的比例由国家统一规定
  • 税盘显示已反写
  • 帝国cms怎么样
  • 银行本票存款属于款项吗
  • 营业外支出增加记借方还是贷方
  • 差旅费具体包括哪些
  • 固定资产折旧加计扣除最新政策
  • 建筑企业结转收入方法
  • 增值税扣税公式
  • 企业所得税汇算表
  • 三代手续费企业所得税
  • 企业代扣个人社保最新会计处理
  • 外经证是干什么用的
  • 增值税收入的确认时间
  • 固定成本包括哪些项目
  • SQL Server中通过扩展存储过程实现数据库的远程备份与恢复
  • mysql 分组语句
  • linux lv扩容
  • u启动怎么装机
  • win8突然没有声音
  • drawand paint
  • perl -pi
  • js 数组 增加元素
  • linux查看目录的权限的命令
  • dos判断变量是否为空
  • JavaScript驾驭网页-DOM
  • ip地址编址方法
  • python中执行同一函数3次
  • ansible客户端需要装python
  • jquery对动态生成的进行操作
  • TextWatcher实现一键清空EditText
  • 宾馆税务
  • 授课费800元个税要收吗
  • 一季度土地市场
  • 广东省国家税务总局电子税务局
  • 交叉互查的作用和意义
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设