纯CSS实现鼠标悬停显示图片效果的实例分享

前端技术 2023/09/08 CSS

最近在做一个网盘的项目,用到了鼠标移上去效果,这个效果可以用js来实现,今天主要分享一下,这个效果如何用纯css实现!

效果如下图:

html代码

XML/HTML Code复制内容到剪贴板
  1. <table id=\"filelist\" style=\"width:100%;\">  
  2.    <tbody>  
  3.         <tr>  
  4.             <td class=\"filename ui-draggable ui-droppable\"  width=\"30%;\">  
  5.                 <div class=\"name\">  
  6.                     <span class=\"fileactions\">  
  7.                         <a href=\"#\" class=\"action action-download\" data-action=\"Download\" original-title=\"\">  
  8.                             <img class=\"svg\" src=\"svg/download.svg\">  
  9.                             <span>下载</span>  
  10.                         </a>  
  11.                         <a href=\"#\" class=\"action action-share permanent\" data-action=\"Share\" original-title=\"\">  
  12.                             <img class=\"svg\" src=\"svg/public.svg\">  
  13.                             <span>已共享</span>  
  14.                         </a>  
  15.                     </span>  
  16.                 </div>  
  17.             </td>  
  18.             <td class=\"filesize\" style=\"color:rgb(-4780,-4780,-4780)\">70.3 MB</td>  
  19.             <td class=\"date\">  
  20.                 <span class=\"modified\" title=\"September 29, 2014 14:45\" style=\"color:rgb(0,0,0)\">2 分钟前</span>  
  21.                 <a href=\"#\" original-title=\"删除\" class=\"action delete delete-icon\"></a>  
  22.             </td>  
  23.         </tr>  
  24.   
  25.         <tr >  
  26.             <td class=\"filename ui-draggable ui-droppable\"  width=\"30%;\">  
  27.                 <div class=\"name\" >  
  28.                     <span class=\"fileactions\">  
  29.                         <a href=\"#\" class=\"action action-download\" data-action=\"Download\">  
  30.                             <img class=\"svg\" src=\"svg/download.svg\">  
  31.                             <span>下载</span>  
  32.                         </a>  
  33.                         <a href=\"#\" class=\"action action-share\" data-action=\"Share\">  
  34.                             <img class=\"svg\" src=\"svg/share.svg\">  
  35.                             <span>分享</span>  
  36.                         </a>  
  37.                     </span>  
  38.                 </div>  
  39.             </td>  
  40.             <td class=\"filesize\" style=\"color:rgb(159,159,159)\">762 kB</td>  
  41.             <td class=\"date\">  
  42.                 <span class=\"modified\" style=\"color:rgb(0,0,0)\" original-title=\"September 29, 2014 16:36\">2 分钟前</span>  
  43.                 <a href=\"#\" original-title=\"删除\" class=\"action delete delete-icon\"></a>  
  44.             </td>  
  45.         </tr>  
  46.         </tbody>  
  47. </table>  

上面代码我直接从项目中复制,可能有很多多余的css,大家只是看下大致代码!

精华的css

图片中的效果,大致的实现思路是,一开始设置为opacity=0,然后鼠标移上去之后显示。

代码如下:

CSS Code复制内容到剪贴板
  1. #filelist a.action {   
  2.     displayinline;   
  3.     padding18px 8px;   
  4.     line-height50px;   
  5.     -ms-filter: \"progid:DXImageTransform.Microsoft.Alpha(Opacity=0)\";   
  6.     filter: alpha(opacity=0);   
  7.     opacity: 0;   
  8.     display:none;   
  9. }   
  10. #filelist tr:hover a.action , #filelist a.action.permanent{   
  11.     -ms-filter: \"progid:DXImageTransform.Microsoft.Alpha(Opacity=50)\";   
  12.     filter: alpha(opacity=50);   
  13.     opacity: .5;   
  14.     display:inline;   
  15. }   
  16. #filelist tr:hover a.action:hover {   
  17.     -ms-filter: \"progid:DXImageTransform.Microsoft.Alpha(Opacity=100)\";   
  18.     filter: alpha(opacity=100);   
  19.     opacity: 1;   
  20.     display:inline;   
  21. }  

以上是大致的精华代码!

css技巧分析

tr鼠标移上去,下面的a标签显示可以这么选择 #filelist tr:hover a.action 加入tr鼠标移上去hover了,那么tr下面的a标签的鼠标移上去效果同样有用,这么写: #filelist tr:hover a.action:hover

jquery中有attr,活动标签的属性,css也可以和jquery一样的类似选择。

例如下面的这个a标签

XML/HTML Code复制内容到剪贴板
  1. <a href=\"#\"  data-action=\"Rename\"  class=\"action\"></a>  

我们可以这么写样式:

CSS Code复制内容到剪贴板
  1.  a.action[data-action=\"Rename\"]{   
  2.     padding16px 14px 17px !important;   
  3.     positionrelative;   
  4.     top: -21px;   
  5. }  

看了这篇文章,您有收获吗?不知道通过这篇文章,您对CSS有没有更近一步的了解!

本文地址:https://www.stayed.cn/item/21254

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。