浅谈javascript中this在事件中的应用


this关键字在javascript中是非常强大的,但是如果你不清楚它是怎么工作的就很难使用它.

复制代码 代码如下:

function dosomething(){ this.style.color="#fff"; }

上面这段代码中的this指向什么呢,运行dosomething()会输出什么呢?

在javascript中,this总是指向当前执行的这个函数,或者把函数作为方法调用的这个对象.当我们在页面上定义dosomething()这个方法后,this的所有者就是当前的页面,或者说是全局对象.

所以我们执行dosomething()这个函数,会引发错误.因为函数的this指向的是全局对象window,而window对象没有style属性.

复制:

复制代码 代码如下:

element.onclick=dosomething;

dosomething()现在被整个复制到onclick属性上作为一个方法.所以如果这个事件执行的话,this就指向这个HTML元素,相应HTML元素的color就会改变.dosomething每次复制到事件上,this就会指向当前执行这个方法的html元素.

引用:

复制代码 代码如下:

<element onclick="dosomething()">

此时你没有复制这个方法,而是引用了这个方法,onclick属性并不包含实际的方法,仅仅只是一个方法的调用.当我们执行这个方法时,this再次指向全局window对象并引发错误.

以上就是本文的全部内容了,有需要的小伙伴好好来研究下吧。



相关阅读:
jquery与prototype框架的详细对比
.net中下载文件的实例代码
iOS开发使用XML解析网络数据
360卫士升级win10系统遇到c盘剩余空间不足该怎么办?
win10输入法设置的位置在哪里?
jquery修改属性值实例代码(设置属性值)
平板怎么升级win10?win8.1升级win10教程
jquery实现非叠加式的搜索框提示效果
基于zepto.js简单实现上传图片
Win10 Mobile RedStone预览版14267已知问题与修复内容汇总
C#创建数据库及导入sql脚本的方法
在ASP.NET 2.0中操作数据之四:使用ObjectDataSource展现数据
Java连接操作Oracle数据库代码详解
JavaScript获取当前日期是星期几的方法
快速导航

Copyright © 2016 phpStudy |