位置: 编程技术 - 正文

JavaScript中的this到底是什么(一)(javascript中的this属性)

编辑:rootadmin

推荐整理分享JavaScript中的this到底是什么(一)(javascript中的this属性),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:JavaScript中的数据类型分哪为两大类?,JavaScript中的变量名不区分大小写,JavaScript中的变量名不区分大小写,javascript中的this属性,JavaScript中的NaN代表什么,JavaScript中的NaN代表什么,javascript中的this指向变量,javascript中的this属性,内容如对您有帮助,希望把文章链接给更多的朋友!

对于常年使用C++,C#,Java等这些面向对象语言的程序员来说,几乎天天都和this打交道。在这些语言里,this含义非常明确,就是指向当前的对象实例,我们用起来也是相当的放心。然而,到了JavaScript这个动态语言里,this的写法没变,但是其含义却大大地不同了,下面用实例说明,使用浏览器为Firefox.0.1.

首先,Hello World o(^?^)o

本人从刚开始自学javascript这门灵活的编程语言到现在,也有一年多的时间了。

在这一年多的时间里,这门语言所带给我的不仅是高额的工作回报,还有很多意想不到的惊喜,让我这样一个艺术生领略编程的魅力。

从今天开始,准备每周一更我的博客,不止是分享,更是勉励自己。

OK,我们进入今天的主题,今天我们来谈谈javascript里面一个比较特殊的对象:this

接触过其他面向对象的编程语言(如:java,C,C++等)的小伙伴们可能对this非常熟悉。

不过它在javascript当中为什么会经常性的给我们造成很多麻烦呢?

我们先来说说他与其他编程语言的不同

在javascript里面,this是一个特殊的对象,它不像其他编程语言那样,是存储在实例中的值,直接指向此实例。

而是作为一个单独的指针,在不同的情况之下,指向不同的位置,这也是为什么我们会将它搞混的原因。

下面我们来看下,它在不同情况下分别是怎样一种形态

1.在全局作用域时:

这个是最好理解的,即在全局作用域下this指向window,也就是在全局作用域下,this与window是等价的:

另外,由于在此时,this等价于window,所以我们在全局作用域声明的变量也会指向this:

当然,我们还有另一种声明变量的方法:

当声明变量时不使用 var 或者 let的话 此时相当于给全局的this添加或者改变属性值

JavaScript中的this到底是什么(一)(javascript中的this属性)

看起来还是很简单的,不就是个等价于window的对象么。

当然,如果仅仅是这样,this或许根本就没有存在的必要了。

而this最让人头疼的部分就是它在不同的作用域下,它的形态也是截然不同的

2.当在函数中时:

到这里时,this的陷阱已经渐渐显露出来了

这里为什么说是当在函数中而不是局部作用域时,要讲这个,首先我们要清楚function是什么

在javascript中,function作为js中的一个特殊对象:函数,是有着不同的形态的

我们通常看到的:

在这一形态下,其内部的this是与全局作用域时一样,直接指向window,所以其形态 依然等价于window。

这里就是经常容易犯得错误,很多人觉得,当this已经在一个function之中时,其目前所处位置为当前的局部作用域,所以目前指向的应该是此函数

但是,如果你将这个函数实例化(new)之后,此函数将生成一个全新的环境,此时在此实例中的this也会随之发生变化,它将指向所在实例。

这是因为,当实例化之后,此函数变成了一个实例对象,而其内部的this也自然而然的指向了此实例对象,如同一开始的this是指向window的对象一样指向了它所在的实例

另外,在我们写javascript的时候,我们通常还会有一种调用函数的方法,即为元素绑定事件,比如button.addEventListener(‘click', fn, false)等,如果在fn里面需要使用到this的话,那么此时this指向事件处理元素,也就是button

注意:this作为关键字,你是无法复写它的。

不知不觉,写的也好多了,其实this还有更多的形态,比如prototype,比如在html中,比如在dom事件处理程序里,由于篇幅过长,这里就不再继续进行敖述,下回我会讲到在prototype中的this

this在我的理解中作为一个指针,相应的它在prototype原型链中会有更重要的地位,不过不在我们今天的范围之内,暂不做过多的解释

以后基本会每周一更吧,作为javascript的新手,也希望写的东西可以跟更多人分享,更希望从大家的思想中总结更多的经验!

关于JavaScript中的this到底是什么(一),每周一都会给大家更新的,作为javascript的新手,希望写的东西可以和身边的朋友分享,更希望互相交流学习经验。谢谢!

js实现的星星评分功能函数 本文实例讲述了js实现的星星评分功能函数。分享给大家供大家参考,具体如下:!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""

JavaScript程序设计之JS调试 本文主要通过一个加法器,介绍JS如何调试。先上代码:效果:test.html:spanstyle="font-family:ComicSansMS;font-size:px;"!DOCTYPEhtmlhtmllang="en"headmetacharset="UTF-8"title

深入浅析react native es6语法 reactnative是直接使用es6来编写代码,许多新语法能提高我们的工作效率解构赋值var{StyleSheet,Text,View}=React;这句代码是ES6中新增的解构(Destructuring)赋值语句

标签: javascript中的this属性

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

上一篇:js实现的奥运倒计时时钟效果代码

下一篇:js实现的星星评分功能函数(js new实现)

  • 如何注销一般纳税人账户
  • 年度应纳税所得额计算公式
  • 本年计算扣除限额的基数怎么算
  • 城市维护建设税是什么意思
  • 2021年增值税专用发票红冲发票步骤
  • 公司办理食品许可证
  • 制造费用折旧费转入生产成本吗
  • 营业外支出计入
  • 12月份费用可以计提吗
  • 增资扩股投资方要交印花税吗
  • 社保滞纳金能否超过本金
  • 增值税发票抵扣期限最新规定
  • 专用发票抵扣联丢失怎么办最新规定
  • 金融企业贷款利率
  • 电子发票怎么作废操作流程视频
  • 固定资产内部转移单
  • 通用申报表工会经费可以不申报吗
  • 免租期间房产税计税依据
  • 资产账实不符说明
  • 低价销售存货的企业所得税怎么算
  • 银行有流水但是没有开票怎么做账
  • 超市开具预付卡发票不征税发票上税吗
  • 防伪税控发票维修流程
  • SQL Server2005、2008如何彻底删除卸载并重新安装?
  • 民间非盈利组织会计要素组成
  • 会计上金融资产包括哪些
  • 调增应纳税所得额季度申报表怎么填
  • 进项发票如何抵扣销项发票
  • 安装win7的步骤
  • Uncaught TypeError: XXX is not a function问题解决方法
  • 收到客户付款 会计分录
  • 收到违约金赔款计入什么科目
  • php options
  • 股东借款给公司会计分录
  • 利息收入增值税确认时点
  • 购买房屋用于出租算投资房吗
  • 建筑业挂靠经营行为有什么涉税风险?
  • 应付债券的应付利息怎么计算
  • 结转已销售产品的实际生产成本会计分录
  • 职工食堂外包账务怎么做
  • 一般纳税人公司出售旧车怎么开票
  • uniapp宽度
  • vue跨域的几种方式
  • 命名空间 php
  • 资产负债表中的货币资金怎么算
  • java泛型的定义和使用
  • ubuntu 14.04 安装分区教程
  • 金蝶固定资产累计折旧凭证生成
  • 2021年废铁回收
  • 影响企业营业利润的有哪些
  • 文化事业建设费2023年是否减免了
  • 普通发票的金额包含增值税吗
  • 息税前利润怎么算出来的
  • 个人工资怎么合理避税有什么方法
  • 2020年账簿印花税减免政策
  • 以前的房产证现在能过户吗
  • 银行手续费必须开发票的规定
  • MySQL数据库同时查询更新同一张表的方法
  • 电脑主机windows 7
  • 组建,加入或退出工会都是基于
  • mac 邮箱
  • linux中python命令
  • xp系统注册表在哪
  • win81蓝屏重启故障
  • magento开发教程
  • PQIMountSvc.exe是什么进程 PQIMountSvc进程查询
  • win10 1511版本升级到1803
  • shell 字符串trim
  • 被人遗忘的明星
  • axios使用jsonp
  • javascript怎么学
  • 抽奖小程序模板
  • javascript入门教程
  • css弹性布局是什么
  • 安卓手机安装推特
  • 医保可以异地交嘛
  • 治理体系治理能力十九届四中
  • 税务登记证书怎么办
  • 烟叶税是谁交
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设