浅谈javascript中this在事件中的应用
作者:bea
this关键字在javascript中是非常强大的,但是如果你不清楚它是怎么工作的就很难使用它. 代码如下: function dosomething(){ this.style.color="#fff"; } 上面这段代码中的this指向什么呢,运行dosomething()会输出什么呢? 在javascript中,this总是指向当前执行的这个函数,或者把函数作为方法调用的这个对象.当我们在页面上定义dosomething()这个方法后,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对象并引发错误.
以上就是本文的全部内容了,有需要的小伙伴好好来研究下吧。
有用 | 无用
代码如下:
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对象并引发错误.
以上就是本文的全部内容了,有需要的小伙伴好好来研究下吧。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- js实现单击图片放大图片的方法
- js实现iframe自动自适应高度的方法
- js全选实现和判断是否有复选框选中的方法
- Jquery树插件zTree用法入门教程
- js实现九宫格图片半透明渐显特效的方法
- JS+CSS实现Li列表隔行换色效果的方法
- JavaScript实现文字与图片拖拽效果的方法
- jQuery实现点击图片翻页展示效果的方法
- JS+CSS实现可拖动的弹出提示框
- js实现下拉框选择要显示图片的方法
- js实现点击图片将图片地址复制到粘贴板的方法
- js实现鼠标经过时图片滚动停止的方法
- js鼠标点击图片实现随机变换图片的方法
- JavaScript简介
- JavaScript的原型继承详解
- javascript 闭包详解
- PhotoShop给图片自动添加边框及EXIF信息的JS脚本
- 浅析javascript中函数声明和函数表达式的区别
- 不同编码的页面表单数据乱码问题解决方法