我一opacity = 1
开始有一个图像。
当鼠标进入图像时,更改opacity = 0.5
。当鼠标离开图像时,将不透明度改回。
这是一个代码:
mouseEnter() {
console.log('mouse enter')
const classname = '.' + this.props.post.code
document.querySelector(classname).classList.add('image-hover-opacity')
}
mouseLeave() {
console.log('mouse leave')
const classname = '.' + this.props.post.code
document.querySelector(classname).classList.remove('image-hover-opacity')
}
render() {
<img src={src} onMouseEnter={::this.mouseEnter} onMouseLeave={::this.mouseLeave} />
}
onMouseEnter 和 onMouseLeave 在鼠标进入和离开图像时分别触发,很好。但问题是当我在图像内移动鼠标时, onMouseEnter 和 onMouseLeave 都会被触发。
我也尝试过 css 解决方案,当我将鼠标悬停在图像上时,更改不透明度属性。但问题是一样的:当我在图像内移动鼠标时, :hover 和 not hover 被多次触发。
如何解决这个问题?谢谢
更新 我以前的代码中有一些东西。创建了一个jsfiddle,它可以工作。对不起大家