vue中对鼠标划过进行处理

鼠标事件进行监听

需求中,在一个table(组件)表中,对于其中一列(该列为图片列),当鼠标划过该列的某个单元格子(图片)时,需要展示出该单元格子对应的遮罩层

翻阅了一些博客,发现好多都提到了mouse事件,如mouseover、mouseout、mouseenter、mouseleave,在之后我自己也通过这种方法进行了尝试。

<template><el-table:data="tableData"stripestyle="width: 100%"><el-table-columnprop="pic"label="图片"width="180"><template slot-scope="scope"><div slot="wrapper" class="name-wrapper"><div class="img-mask" @click="toShowDialog(props.row)" :ref="'mask' + props.rowIndex">文字</div><div @mouseover="changeMask(props.rowIndex)" @mouseout="changeMask(props.rowIndex)"><img src="..."></div></div></template></el-table-column></el-table>
</template>...
changeMask(index) {let vm = this;let mask = vm.$refs['mask' + index];if(mask.style.display == 'none') {mask.style.display = 'block';}else {mask.style.display = 'none';}
}

最后在查看结果中发现,在划过的时候是会触发鼠标事件,但是会出现闪动的清空,当鼠标一直放在该单元格上的时候,遮罩层也会消失和出现反复切换。为缓解这种情况,还对changeMask中的显示和隐藏进行setTimeout延时,结果并不理想,不推荐这样使用。

CSS方式实现

这种方法,只需要保留上面代码中的主体部分,不需要ref和mouse事件这些,主要是通过opacity去控制遮罩层的显示和隐藏的。具体的样式代码如下:

.wrapper {position: relative;.img-mask {position: absolute;background: rgba(0, 0, 0, 0.5);z-index: 10;//设置left、right、top、bottom的原因是使得遮罩层上的文字显示在该层的最中间left: 0;right: 0;top: 0;bottom: 0;//透明度为0,则就是不可见opacity: 0;}&:hover {.img-mask {opacity: 1;}}
}

这种方法达到了预期的效果,体验也很好,推荐使用。

table中动态ref

首先,这部分并不是针对遮罩层显示隐藏的,而是处理表格中某一列或者很多单元格添加ref的。这个其实在第一种方法中就已经也出来了,现在做下总结。

:ref="'mask' + props.rowIndex"这种方法对例如表格这样一列中的每个单元格都对应着一个附加的东西,而这些东西的位置又是不同的,可以实现对每个单元格进行ref绑定,在事件处理函数中,通过传递props.rowIndex得到下标,最终通过this.$ref['mask' + props.rowIndex]得到对应的元素,然后对其css进行相关控制(只是举例)。

感谢给我提解决办法的人,继续努力,加油↖(^ω^)↗

vue中对鼠标划过事件处理方式相关推荐

  1. vue划入划出事件_基于vue中对鼠标划过事件的处理方式详解

    鼠标事件进行监听 需求中,在一个table(组件)表中,对于其中一列(该列为图片列),当鼠标划过该列的某个单元格子(图片)时,需要展示出该单元格子对应的遮罩层 翻阅了一些博客,发现好多都提到了mous ...

  2. vue中过渡动画(类名实现方式)

    vue中过渡动画分为两类,一类是进场动画,一类是出场动画 要实现上面的进场动画,主要有三种方式:类名,css动画库,js函数 类名 本质就是动态添加类名实现动画 在进入/离开的过渡中,会有 6 个 c ...

  3. Vue中使用 class 类样式的方式

    在vue中为我们提供了 几种方式来使用class类的样式 1. 布尔值 我们先正常在 style 标签中 书写一个类名为 active的样式 <style>.active{color: r ...

  4. vue中data定义数字类型_[乐意黎原创] Vue中data定义的三种方式和区别

    在 Vue中,定义data时,经常有好几种写法,一不小心会混淆,这里彻底详述一下,以便记分清 . 一.在vue中,定义data可以有三种写法. 1. 第一种写法,data是一个对象. var app ...

  5. VUE中页面跳转的常用方式及返回上一页实现的两种方式

    一.我们知道,如果是一个页面的某些部分切换变化,那不是网页之间的切换,而是子组件的切换:对于页面切换,我们需要知道的是整个页面的内容和路径都发生了改变.在原生JS中我们知道页面切换可以使用locati ...

  6. vue中组件之间传值的六种方式(完整版)

    前言   组件是 vue.js 最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用.一般来说,组件可以有以下几种关系: 如上图所示,A 和 B.B 和 C.B ...

  7. Vue中父子组件传值的多种方式

    vue中父子组件传值 vue中的父子组件传值,值得注意的是要遵守单向数据流原则.所谓单向数据流原则,简单的说就是父组件的数据可以传递给子组件,子组件也可以正常获取并使用由父组件传过来的数据:但是,子组 ...

  8. Vue中实现骨架屏的多种方式

    vue-cli项目首页加载缓慢想要使用骨架屏效果,经过几天的实践,这里学习并记录一下vue项目自动生成骨架屏方法.  前言:骨架屏的作用主要是在网络请求较慢时,提供基础占位,当数据加载完成,恢复数据展 ...

  9. 在vue中使用鼠标事件@mousedown、@mouseenter等失效的解决办法,以及PC端长按实现

    问题解决 @mouseenter.@mousedown等鼠标事件[非鼠标点击事件]时,发现事件不触发,失效了 此时应该在@mouseenter.@mouseenter等鼠标事件加上native属性就好 ...

  10. vue中实现动画效果--三种方式

    一.普通动画实现 效果 用一个按钮, 控制一个 div 的淡入和淡出 步骤 使用 js 控制 div 的 class name 点击 function anime() {var boxDom = do ...

最新文章

  1. PHP之源码目录结构
  2. 关于MVC与三层架构、个人总结网上杂七杂八得出的最终成果、asp.net (core) MVC、JavaWeb的MVC
  3. collect的功能是什么?其底层如何实现的?_用Python实现定时自动化收取蚂蚁森林能量,再也不怕被偷了
  4. weblogic 故障转移
  5. “智能微尘”:助推物联网应用的关键
  6. 在安卓模拟器中,adb安装apk常见错误
  7. PAT 1044. 火星数字
  8. eigen3.3.8帮助文档下载 chm_惠普7500A驱动下载-惠普hp 7500A打印机驱动下载 v28.8官方版...
  9. 情报使能 合作共赢 | TI INSIDE计划发布会即将开始
  10. Git教程——入门基础
  11. java加按钮_用java写一个简单的学生信息管理系统
  12. 利用SPSS Modeler进行数据挖掘——探究不同程序语言的就业情况
  13. linux addr2line 用法,addr2line的用法
  14. 面试技巧(2) 个人面试注意事项
  15. 2015061710 - 海豹突击队的忠告
  16. 计算机协会素拓小游戏,素拓游戏策划书-20210418231500.doc-原创力文档
  17. Navigating to current location (/user) is not allowed
  18. 计算机网络基础知识1
  19. 线性回归原理及实现(一):最小二乘法
  20. Google桌面搜索中文版印象(转)

热门文章

  1. 计算机休眠和睡眠省电,几步教会你笔记本睡眠和休眠有什么区别
  2. CDMA(Code Division Multiple Access码分多址)
  3. 求齐次线性方程组的基础解系matlab,MATLAB学习笔记:齐次线性方程组的基础解系...
  4. go实现文档中保存的微信图片.dat格式解密为图片
  5. Java去掉红色印章,基于RGB和HSV实现红色公章删除
  6. 节假日查询 API数据接口
  7. 项目绩效考核管理有何方法?这7大考核方案你都知道吗?
  8. python中temp是什么意思_.temp(temp是什么意思?)
  9. 哈希碰撞,改变世界的原力
  10. 知名清理工具或成恶意软件