位置: 编程技术 - 正文

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)

  • 企业所得税年报申报时间
  • 进项税额转出会计分录月末如何结转
  • 食用油交不交消费税
  • 稿费的个人所得税税率是多少
  • 销售额负数怎么报税
  • 个体户开票超30次后如何开票
  • 资产负债表负债总额怎么看
  • 怎么才算小企业
  • 小规模纳税人开票税率
  • 企业所得税债务重组所得
  • 银行承兑个人可以接受吗
  • 贷款公司收取服务费是诈骗吗
  • 废品材料回收价格
  • 股票转让所得不交增值税
  • 公司买手机可以开票抵扣吗
  • 增值税小规模纳税人免征增值税政策
  • 建筑业小规模纳税人认定标准
  • 企业销售货物因违规处罚
  • 在建工程可以质押吗
  • 购买原材料的运费属于什么费用
  • windows 临时文件夹
  • swimsuitnetwork.exe - swimsuitnetwork是什么进程 有何作用
  • 工程安装成本分录
  • 公司收到个人的款怎么做账务处理
  • 借助的近义词
  • php导入
  • phpjson
  • 鸿蒙系统进入工程菜单
  • ccs是什么软件
  • microsoftedge怎么转换成ie
  • lsass.exe是什么程序
  • 无损数据分区
  • yolov3 改进
  • 向银行贷款资金成本率计算公式是什么
  • thinkphp smarty
  • 减征增值税会计处理
  • 计算机视角技术
  • 基于stm32的毕业设计
  • 上市公司发行股票会计分录
  • 企业年报分析的内容包括哪些方面
  • 帝国cms怎么用
  • java多线程经典案例
  • 申报的财务报表在哪里查询
  • 新会计准则规定
  • 工资总额主要包括
  • 建筑公司包工包料提供建筑服务
  • 增值税专用发票怎么开
  • 小规模公司购买汽车会计分录
  • 营改增的服务
  • 应付账款的发生额怎么算
  • 微信提现手续费1000扣多少
  • 发票边上的孔有什么用
  • 原始凭证按什么分
  • 以前年度收入少记了怎么做分录
  • 融资租赁本金和租金的区别
  • 残疾人就业保障金
  • 房地产开发企业资质管理规定
  • 应付??
  • 新企业设置账簿
  • sql中cursor是什么意思
  • 完美解决usb供电不足
  • mysql两种安装方式
  • xp浏览器无法浏览网页
  • windows正版光盘
  • centos7 samba服务器搭建
  • ubuntu英文系统安装中文输入法
  • centos32
  • 实用的linux命令
  • cocos2dx4.0教程
  • nodejs自启动
  • linux命令sed的用法
  • vue-cli作用
  • node.js的exports、module.exports与ES6的export、export default深入详解
  • php实现登录功能
  • Javascript valueOf 使用方法
  • jquery ui教程
  • python2设置环境变量
  • 税务局执法不规范整改
  • 宁波增值税普通发票有几联发票
  • 国有企业租赁经营 河北省
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设