我有一个图像,开始时opacity = 1.
当鼠标进入图像时,更改不透明度= 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解决方案,当我将鼠标悬停在图像上时,更改不透明度属性.但问题是一样的:当我在图像中移动鼠标时,:悬停而不是悬停被多次触发.
怎么解决这个?谢谢
解决方法
使用document.querySelector并不是一种非常反思的思维方式.你可以尝试这种方法:
>使用包装此img的div来避免这种奇怪的mouseEnter行为
>将this.state与不透明度一起使用
constructor() { this.state = { opacity: 1 } } mouseEnter() { console.log('mouse enter') this.setState({opacity: 0.5}) } mouseLeave() { console.log('mouse leave') this.setState({opacity: 1}) } render() { <div style={{opacity: this.state.opacity}}> <img src={src} onMouseEnter={::this.mouseEnter} onMouseLeave={::this.mouseLeave} /> </div> }