Html5 css3 左箭头,利用CSS3特性巧妙实现漂亮的DIV箭头

DIV箭头用于表现DIV内容的指向,是使用非常普遍的一种表现形式,例如新浪微博的消息转发:

![](https://box.kancloud.cn/2016-08-02_57a05bce5c7df.gif)

还有傲游网站的导航条:

![](https://box.kancloud.cn/2016-08-02_57a05bce74be8.gif)

像傲游账户上方这种箭头更需要多幅图片以表现箭头和hover的效果。

![](https://box.kancloud.cn/2016-08-02_57a05bce880ed.gif)

传统的实现方式都需要一副表示箭头的图片放在DIV上方来实现,例如新浪微博的相关CSS如下:

![](https://box.kancloud.cn/2016-08-02_57a05bce994d4.gif)

而使用CSS3的特性,我们不需要图片就可以实现更加华丽的效果,这样做的好处还包括减少本地文件系统的读取、节省服务器带宽和连接数、避免文件下载失败带来的错误等等。

实现的原理是:我们可以将箭头看作是一个矩形或者菱形的一个角,使用CSS3的属性transform来实现矩形的旋转。

朝上的箭头需要将矩形旋转45度,我们使用transform: rotate(45deg)来实现,另外针对不同的浏览器还需要添加不同的hack,例如Opera的-o-transform、Firefox的-moz-transform,下面以Chrome浏览器为例实现一个样例。

定义一个arrow-shadow样式,内容如下:

~~~

.arrow-shadow {

-webkit-transform:rotate(45deg);

border:1px solid #AAAAAA;

height:40px;

position:absolute;

width:40px;

}

~~~

实现的效果如下所示:

![](https://box.kancloud.cn/2016-08-02_57a05bceafc2b.gif)

为了更加饱满,我们加上CSS3的盒阴影,

~~~

.arrow-shadow {

-webkit-transform:rotate(45deg);

-webkit-box-shadow:0 0 10px 0 #aaa;

height:40px;

position:absolute;

width:40px;

}

~~~

现在效果如下:

![](https://box.kancloud.cn/2016-08-02_57a05bcec17e7.gif)

在外面加一层DIV控制它的高度和宽度。

~~~

.arrow-outer {

height:24px;

overflow:hidden;

position:absolute;

width:60px;

}

~~~

效果如下:

![](https://box.kancloud.cn/2016-08-02_57a05bced2f20.gif)

现在我们已经有了一个漂亮的箭头,但是这还不够,为了表现得更加出色,我们再加一层内部的箭头。

![](https://box.kancloud.cn/2016-08-02_57a05bcee5d2d.gif)

关键代码和结构如下:

~~~

.arrow-outer {

position:absolute;

height:24px;

width:60px;

overflow:hidden;

}

.arrow-shadow {

-webkit-box-shadow:0 0 10px 0 #AAAAAA;

-webkit-transform:rotate(45deg);

background:none repeat scroll 0 0 #FFFFFF;

height:40px;

left:15px;

position:absolute;

top:16px;

width:40px;

}

.arrow-inner {

position:relative;

left:10px;

top:20px;

height:40px;

width:40px;

background:#fff;

border:5px solid #ededed;

-webkit-transform:rotate(45deg);

transform:rotate(45deg);

}

~~~

在外面加上一层容器,就可以看到箭头了。

![](https://box.kancloud.cn/2016-08-02_57a05bcf06925.gif)

最后完整的效果图如下所示:

![](https://box.kancloud.cn/2016-08-02_57a05bcf1fdfc.gif)

CSS3、HTML5的发展和完善让我们编写代码更加简便和快捷,实现的效果也更加漂亮,例如背景的渐变不再需要背景图片的平铺就可以通过CSS代码直接实现,但是有时候需要经过一些转换,才能将这些新技术应用到我们常见的功能中去,这需要我们多加思考和保持思维的灵感。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值