vue中在循环中使用@mouseenter 和 @mouseleave事件闪烁问题解决方法

vue中在循环中使用@mouseenter 和 @mouseleave事件闪烁问题解决方法

最近在项目中实现在循环出来的图片中当鼠标移入隐藏当前图片显示另一张图片的需求时碰到了一个小问题。就是当使用@mouseenter 和@mouseleave事件来实现这个需求时却发现鼠标移入后图片出现闪烁现象。


重点:事件写到父元素上才行!!! 0.0

下面写下我的实现方法和实现效果

样式代码:

<div class="imgs" v-for="(item,index) in exampleUrl" :key = index  @mouseenter ="enterFun(index)" @mouseleave ="leaveFun(index)" >                     
        <img :src = item.url  v-show="show ||  n != index" >                               
        <div   v-show="!show  && n == index" >查看详情</div>
</div>

其他代码:

export default {
	data () {
	    return {
	        n: 0,
	        show:true,
	    }
	} ,
	methods: {
		enterFun(index){
		    console.log('鼠标移入');
		    this.show = false;
		    this.n = index;
		},
		leaveFun(index){
		    console.log('鼠标离开');
		    this.show = true;
		    this.n = index;
		},
	}       
}

最终实现效果如图 当鼠标移入图片时当前图片显示查看详情:
在这里插入图片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章