首页 > 代码库 > 纯CSS实现的右侧底部简洁悬浮效果

纯CSS实现的右侧底部简洁悬浮效果

我们见过很多页面右侧浮动效果,最早有QQ联系面板,对联广告等,大多数都是基于Javascript实现的动态效果,今天我给大家分享一个只需要CSS结合DIV实现的右侧浮动效果。

HTML

我们希望悬浮效果最后加载,因此一般将其放置在页面HTML的末尾,我们建立一个.side-bar,里面包含了QQ在线咨询,微信(鼠标滑向弹出二维码效果),微博,以及Email联系方式等内容,这些内容我们都以<a>标签包裹。

 
<div class="side-bar">      <a href="http://www.mamicode.com/#" class="icon-qq">QQ在线咨询</a>      <a href="http://www.mamicode.com/#" class="icon-chat">微信<div class="chat-tips"><i></i>     <img style="width:138px;height:138px;" src="http://www.mamicode.com/helloweba.jpg" alt="微信订阅号"></div></a>      <a target="_blank" href="" class="icon-blog">微博</a>      <a href="http://www.helloweba.com/gbook.html" class="icon-mail">mail</a>  </div> 

CSS

我们使用CSS来完成浮动即鼠标滑向弹出效果。我们准备一张图片right_bg.png,包含了几个内容的图标,然后通过background-position各个图标对应的a内容。我们使用position: fixed以及设置bottom和right值将.side-bar固定在右下角,这样无论页面如何滚动,.side-bar将一直在右下角位置不变。这里需要提下ie6下fixed效果需要单独处理,但本文不做详解,放弃ie6吧。

.side-bar a,.chat-tips i {background: url(right_bg.png) no-repeat;} .side-bar {width: 66px;position: fixed;bottom: 20px;right: 25px;font-size: 0;line-height: 0;z-index: 100;} .side-bar a {width: 66px;height: 66px;display: inline-block;#ddd;margin-bottom: 2px;} .side-bar a:hover {#669fdd;} .side-bar .icon-qq {background-position: 0 -62px;} .side-bar .icon-chat {background-position: 0 -130px;position: relative;} .side-bar .icon-blog {background-position: 0 -198px;} .side-bar .icon-mail {background-position: 0 -266px;} 

  

 

这里还有个鼠标滑向微信图标的效果,当鼠标hover时,.chat-tips的display属性设置为block,并且设置定位位置,一下代码还包含了一个箭头的CSS写法:

 
.side-bar .icon-chat:hover .chat-tips {display: block;} .chat-tips {padding: 20px;border: 1px solid #d1d2d6;position: absolute;right: 78px;top: -55px;#fff;display: none;} .chat-tips i {width: 9px;height: 16px;display: inline-block;position: absolute;right: -9px;top: 80px;background-position:-88px -350px;} .chat-tips img {width: 138px;height: 138px;} 

  

简单的几行CSS代码就完成了一个简洁的右下角悬浮效果,快去试下吧。

演示地址:http://www.helloweba.com/demo/fixedright/cssfixed.html

源码下载:http://www.helloweba.com/down-268.html

纯CSS实现的右侧底部简洁悬浮效果