繁体   English   中英

如何传递触发事件并更改其属性的元素?

[英]How to Pass an Element that Triggered an Event and Change a Property of it?

我正在尝试更改<div>元素的background-color 元素触发一个事件,并调用包括元件经由自变量的函数this

如何更改元素属性?

我尝试将传递的元素分配给变量和许多其他试错法,我不记得了。

newDiv = document.addEventListener('mouseover', doSomething(this));

// Some code here

function doSomething(item)
{
  item.style.backgroundColor = '#FFFFFF';
}

我希望元素的背景颜色更改为#FFFFFF ,但我收到此错误消息: TypeError: item.style is undefined

调用函数如下doSomething(this)是不行的。 你实际上绑定了函数doSomething的返回值。

js引擎会自动绑定为触发事件的元素的词汇上下文,因此您可以使用this上下文:

this.style.backgroundColor = '#FFFFFF';

或者,您可以使用在处理程序上作为参数传递的事件:

document.addEventListener('mouseover', doSomething);
function doSomething(e) {
   e.target.style.backgroundColor = '#FFFFFF';
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM