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

(编辑:jimmy 日期: 2025/1/12 浏览:2)

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

效果如下图:
纯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.     display: inline;   
  3.     padding: 18px 8px;   
  4.     line-height: 50px;   
  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.     padding: 16px 14px 17px !important;   
  3.     position: relative;   
  4.     top: -21px;   
  5. }  

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