Web页面中5种超酷的Hover效果


hover 效果能给网页增加一些动态效果,并且使得站点更具有活力。原来的做法是使用javascript来实现这些动态效果,但是随着CSS3的引入和现代浏览器 的支持,我们可以用纯粹的CSS代码来实现这些有趣的效果。所谓的现代浏览器,更多的是指以Mozilla和Webkit为核心的浏览器,IE的表现稍微 差强人意,所以请使用FireFox,Safari或者Chrome查看一下的效果。如下就是要介绍的5个非常酷的纯CSS hover 效果。

1、向上跳跃

Click Here to Launch

这种效果非常适合于当页面上有一横排图片的场景,当鼠标hover时就产生波浪一样的效果。

这个效果实现是非常简单的,并且有多种方法实现,如下的核心实现方法是:初始给所有图片设置margin,当hover时,给相应的图片减少margin的值,这样就实现了向上跳跃的效果。

这种效果不光可以应用于图片,一般的横向排列的导航栏也可以应用这样的效果。

效果中的透明效果是并不是必须的,不设置透明属性并不影响hover时的跳跃效果,加上透明只是为了让效果更平滑。

css代码

1
2
3
4
5
6
7
8
9
10
11
12
.ex1 img{
border: 5px solid #ccc;
float: left;
margin: 15px;
-webkit-transition: margin 0.5s ease-out;
-moz-transition: margin 0.5s ease-out;
-o-transition: margin 0.5s ease-out;
}
.ex1 img:hover {
margin-top: 2px;
}

  层叠与放大

Click Here to Launch

这种效果类似于熔岩灯效果,当鼠标从上至下移动时,每个图片都是慢慢地放大然后恢复到原始的状态。

为了实现这样的效果,首先把原始图片显示的时候缩小一点,当鼠标hover时,放大图片的尺寸。

因为图片是居中显示的,所以当鼠标hover时,也增加了图片的margin,这样使得当图片放大时也是居中的效果。

CSS代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
/*Example 2*/
#container {
width: 300px;
margin: 0 auto;
}
#ex2 img{
height: 100px;
width: 300px;
margin: 15px 0;
-webkit-transition: all 1s ease;
-moz-transition: all 1s ease;
-o-transition: all 1s ease;
}
#ex2 img:hover {
height: 133px;
width: 400px;
margin-left: -50px;
}

 

 文字淡入

Click Here to Launch

类 似的这种效果,一般是用JavaScript来实现的,当hover其中某个元素时,另一个元素发生一些变化。本例为了实现这一效果,首先把图片和文字放 在一个div里,然后设置div的color:transparent和line-height:0px。当hover时,更改color和line- height属性,使得文字显示。

CSS代码

 1 #ex3 {
 2     width: 730px;
 3     height: 133px;
 4     line-height: 0px;
 5     color: transparent;
 6     font-size: 50px;
 7     font-family: "HelveticaNeue-Light", "Helvetica Neue Light", "Helvetica Neue", Helvetica, Arial, sans-serif;
 8        font-weight: 300;
 9     text-transform: uppercase;
10     -webkit-transition: all 0.5s ease;
11     -moz-transition: all 0.5s ease;
12     -o-transition: all 0.5s ease;
13 }
14   
15 #ex3:hover {
16     line-height: 133px;
17     color: #575858;
18 }
19   
20 #ex3 img{
21     float: left;
22     margin: 0 15px;
23 }

旋转的图片

Click Here to Launch

实 现这个效果是非常容易的,但是因为这是一个非常重要的效果,尤其对于画廊中的缩略图。这个效果中我们使用了一些较新的CSS样式。这个例子使用了box- shadows,transitions和transforms。transform是实现旋转部分,transition是为了让效果更平滑。

CSS代码

 1 #ex4 {
 2     width: 800px;
 3     margin: 0 auto;
 4 }
 5   
 6 #ex4 img {
 7     margin: 20px;
 8     border: 5px solid #eee;
 9     -webkit-box-shadow: 4px 4px 4px rgba(0,0,0,0.2);
10     -moz-box-shadow: 4px 4px 4px rgba(0,0,0,0.2);
11     box-shadow: 4px 4px 4px rgba(0,0,0,0.2);
12     -webkit-transition: all 0.5s ease-out;
13     -moz-transition: all 0.5s ease;
14     -o-transition: all 0.5s ease;
15 }
16   
17 #ex4 img:hover {
18     -webkit-transform: rotate(-7deg);
19     -moz-transform: rotate(-7deg);
20     -o-transform: rotate(-7deg);
21 }

  淡入和倒影

Click Here to Launch

这个效果是相对复杂的效果,首先,设置减少图片的初始的透明度,当hover时,把透明度设置回默认值,另外会有一个图片边缘发光的效果和倒影效果(只在以Webkit为内核的浏览器中起作用)。

CSS代码

 1 #ex5 {
 2     width: 700px;
 3     margin: 0 auto;
 4     min-height: 300px;
 5 }
 6   
 7 #ex5 img {
 8     margin: 25px;
 9     opacity: 0.8;
10     border: 10px solid #eee;
11   
12     /*Transition*/
13     -webkit-transition: all 0.5s ease;
14     -moz-transition: all 0.5s ease;
15     -o-transition: all 0.5s ease;
16   
17     /*Reflection*/
18     -webkit-box-reflect: below 0px -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(.7, transparent), to(rgba(0,0,0,0.1)));
19 }
20   
21   
22 #ex5 img:hover {  
23    opacity: 1;
24   
25    /*Reflection*/
26   -webkit-box-reflect: below 0px -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(.7, transparent), to(rgba(0,0,0,0.4)));
27   
28    /*Glow*/
29   -webkit-box-shadow: 0px 0px 20px rgba(255,255,255,0.8);
30   -moz-box-shadow: 0px 0px 20px rgba(255,255,255,0.8);
31   box-shadow: 0px 0px 20px rgba(255,255,255,0.8);
32 }

长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号





    联系我们

    欢迎来到TinyMind。

    关于TinyMind的内容或商务合作、网站建议,举报不良信息等均可联系我们。

    TinyMind客服邮箱:support@tinymind.net.cn