在 React 中,onMouseEnter 或 hover 没有按预期工作
In React, onMouseEnter or hover is not working as expected
我有一张图片以 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,并且有效。
对不起大家
使用document.querySelector
并不是一种很 React 的思维方式。你可以试试这个方法:
- 使用
div
包装此 img
以避免这种奇怪的 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>
}
我真的认为您只能在 CSS 中实现。
所以你的组件应该有简单的 className
属性 并且 class 应该有以下定义:
.image-hover-opacity:hover {
opacity: 0.5;
}
class Example extends React.Component {
constructor() {
super();
this.state = {};
}
render() {
return(
<img className="image-hover-opacity" src="http://i.imgur.com/PLKabDV.png" />
);
}
}
ReactDOM.render(<Example />, document.getElementById('root'));
.image-hover-opacity:hover {
opacity: 0.5;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script>
<div id="root"></div>
我有一张图片以 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,并且有效。 对不起大家
使用document.querySelector
并不是一种很 React 的思维方式。你可以试试这个方法:
- 使用
div
包装此img
以避免这种奇怪的 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> }
我真的认为您只能在 CSS 中实现。
所以你的组件应该有简单的 className
属性 并且 class 应该有以下定义:
.image-hover-opacity:hover {
opacity: 0.5;
}
class Example extends React.Component {
constructor() {
super();
this.state = {};
}
render() {
return(
<img className="image-hover-opacity" src="http://i.imgur.com/PLKabDV.png" />
);
}
}
ReactDOM.render(<Example />, document.getElementById('root'));
.image-hover-opacity:hover {
opacity: 0.5;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script>
<div id="root"></div>