位置: 编程技术 - 正文

JS中的this变量的使用介绍(彻底弄懂js中的this指向)

编辑:rootadmin
JavaScript中this的使用 在JavaScript中this变量是一个令人难以摸清的关键字,this可谓是非常强大,充分了解this的相关知识有助于我们在编写面向对象的JavaScript程序时能够游刃有余。 对于this变量最要的是能够理清this所引用的对象到底是哪一个,也许很多资料上都有自己的解释,但有些概念讲的偏繁杂。而我的理解是:首先分析this所在的函数是当做哪个对象的方法调用的,则该对象就是this所引用的对象。 示例一、 这段代码非常容易理解,当执行 obj.y() 时,函数是作为对象obj的方法调用的,因此函数体内的this指向的是obj对象,所以会弹出。 示例二、 这里为什么会弹出 'this is a property of window',可能有些让人迷惑。在JavaScript的变量作用域里有一条规则“全局变量都是window对象的属性”。当执行checkThis() 时相当于window.checkThis(),因此,此时checkThis函数体内的this关键字的指向变成了window对象,而又因为window对象又一个x属性('thisis a property of window'),所以会弹出 'thisis a property of window'。 上面的两个示例都是比较容易理解的,因为只要判断出当前函数是作为哪个对象的方法调用(被哪个对象调用)的,就可以很容易的判断出当前this变量的指向。 this.x 与apply()、call() 通过call和apply可以重新定义函数的执行环境,即this的指向,这对于一些应用当中是十分常用的。 示例三:call() 注意changeStyle.call()中有三个参数,第一个参数用于指定该函数将被哪个对象所调用。这里指定了one,也就意味着,changeStyle函数将被one调用,因此函数体内this指向是one对象。而第二个和第三个参数对应的是changeStyle函数里的type和value两个形参。最总我们看到的效果是Dom元素one的字体变成了px。 示例四:apply() apply的用法和call大致相同,只有一点区别,apply只接受两个参数,第一个参数和call相同,第二个参数必须是一个数组,数组中的元素对应的就是函数的形参。 无意义(诡异)的this用处 示例五: 如何达到预期的效果 事件监听函数中的this 注意:js中的全局变量都会动态添加到Window 的实例 window,作为其属性。 this是js的一个关键字,随着函数使用场合不同,this的值会发生变化。但是总有一个原则,那就是this指的是调用函数的那个对象。 1、纯粹函数调用。 其实这里的this就是全局变量。看下面的例子就能很好的理解其实this就是全局对象Global。 2、作为方法调用,那么this就是指这个上级对象。 3、作为构造函数调用。所谓构造函数,就是生成一个新的对象。这时,这个this就是指这个对象。 4、apply调用 this指向的是apply中的第一个参数。 当apply没有参数时,表示为全局对象。所以值为0。

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

JS中的this变量的使用介绍(彻底弄懂js中的this指向)

文章相关热门搜索词:js中this的用法,js 中的this,js中的this如何理解,js里的this,js 中的this,js中this的概念,js中this的用法,js中this的用法,内容如对您有帮助,希望把文章链接给更多的朋友!

onkeyup,onkeydown和onkeypress的区别介绍 msdn上有三者的区别:名称说明onkeypress这个事件在用户按下并放开任何字母数字键时发生。系统按钮(例如,箭头键和功能键)无法得到识别。onkeyup这

javascript中的=等号个数问题两个跟三个有什么区别 一个等号就是个赋值的作用,主要问题在于两个跟三个等号的区别。javaScript中两个等于号和三个等于号之间的区别一言以蔽之:==先转换类型再比较,==

JavaScript instanceof 的使用方法示例介绍 在JavaScript中,判断一个变量的类型尝尝会用typeof运算符,在使用typeof运算符时采用引用类型存储值会出现一个问题,无论引用的是什么类型的对象,它

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

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

上一篇:在javaScript中关于submit和button的区别介绍(javascript中的关键字有哪些)

下一篇:onkeyup,onkeydown和onkeypress的区别介绍

  • 受票方与付款方不一致
  • 个人先进奖励要缴纳个税吗
  • 无形资产可以一次性摊销吗?
  • 回单一定要在开户行打吗
  • 自己申报个人所得税需要补缴,必须自己申报自己补缴吗
  • 资本公积转增股本什么意思
  • 票据贴现业务利润怎么算
  • 结转税金为贷方怎么结转?
  • 个人负担社保
  • 付款然后付的手续费如何做账?
  • 销售人员的销售总额怎么算
  • 预收房款发票开具需要注意哪些?
  • 增值税发票免税和0%区别
  • 电子商务平台支付的区别
  • 2018年用2015年的发票入账有什么税务的风险?
  • 未达起征点销售额和其他免税销售额
  • 管理费用纳税调增账务处理
  • 企业所得税上个季度赔钱下个季度挣钱
  • 普票没有税号可以开票吗
  • 技术服务费如何收取
  • 老毛桃u盘启动盘制作工具怎么安装win10系统 老毛桃u盘安装win10系统图文教程
  • linux 列表
  • 会计中的低值易耗品
  • 厂区地面硬化的意义
  • 收到其他公司的投资款计入什么科目
  • 冲销多计提个税怎么做账
  • 单位性质有哪些类型
  • macbookpro安装dmg
  • 专有技术应当得到
  • 差额征税的项目 按差额记账还是全额倒算销项税
  • php7 数组
  • 小企业会计准则调整以前年度费用分录
  • 在高地陶恩山脉的滑雪旅行,奥地利巴德加斯坦 (© RooM the Agency/Alamy)
  • php获取文件后缀名的方法
  • 卷积神经网络有哪些
  • 人才引进的安家费
  • wordpress文章保存在哪里
  • 人力资源公司代办
  • 固定资产折旧应纳税所得额调整
  • 房租押金不退还的账务怎么处理
  • 公对私转账交税
  • 印花税会计处理办法
  • 短期借款财务处理
  • 上年度记错科目怎么调整
  • 冲销以前月份的凭证
  • 旅行社差额征收怎么报税
  • 外账需要计提存利息吗
  • 2010年漏记的费用,11年该如何记账?
  • 营改增税法
  • 总公司可以给子公司开票吗
  • 预计负债 负债 区别
  • 小规模纳税人租赁不动产税率
  • 发票上的数量怎么填写
  • 左右内边距代码
  • win8激活点不进去
  • win10的数据使用量是什么
  • fedora win10
  • xp桌面消失 右击无反应
  • Ubuntu下VirtualBox的vdi文件克隆方法
  • 无线网络连接上但上不了网
  • win7和vista的区别
  • 在Linux系统中如何打开R语言控制台
  • 查找linux
  • win8怎么关闭电脑
  • win10系统内置应用软件有哪些
  • win10商店没有图标
  • 给网页添加javascript
  • nodejs解析路径
  • 环境变量windows
  • jsp中onload事件
  • nodejs搭建本地资源服务器
  • json对象结构中,关键字key必须为什么类型
  • 开票软件连接服务器失败什么原因
  • 高铁票抵扣进项能抵扣吗
  • 哈尔滨出租车可以拼车吗
  • 江苏社保退工办理流程
  • 花卉种植税收优惠政策案例
  • 新税法折旧年限怎么算
  • 河南国税网上办证流程
  • 税款复核需要多少天
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设