技术

Laravel 关联模型由于名称一致性导致的问题 Laravel 核心:控制反转(Inversion of Control)和门面模式(Facade) 回退Mac上用Brew安装的PHP版本 为PHP设置服务器(Apache/Nginx)环境变量 PHP中的魔术方法和魔术常量简介和使用 ROC曲线 设计模式详解及PHP实现 MySQL大量数据插入各种方法性能分析与比较 Laravel中使用Redis作为队列系统的工作流程 使用Supervisor来管理你的Laravel队列 在Laravel中使用自己的类库三种方式 用Laravel+Grunt+Bower管理你的应用 从运行原理及使用场景看Apache和Nginx 了解GitHub工作流【译】 PHP Socket的使用 Apache 日志文件格式及简单处理 Python脚本--下载合并SAE日志 PHP命名空间及自动加载 基于CSS3实现尖角面包屑 部署Ceilometer到已有环境中 OpenStack Ceilometer Collector代码解读 OpenStack Ceilometer数据存储与API源码解析 OpenStack Ceilometer中的Pipeline机制 OpenStack Ceilometer Compute Agent源码解读 学习Python动态扩展包stevedore 学习Python的ABC模块 Python包管理工具setuptools详解 OpenStack Horizon 中文本地化 WSGI学习 在虚拟机单机部署OpenStack Grizzly 学习使用python打包工具distutils python包工具之间的关系 给OpenStack创建Ubuntu镜像 OpenStack Grizzly Multihost部署文档 为什么使用pip而不是easy_install HTML中meta标签viewpoint的作用 交互式编程-IPython 页面提速之——数据缓存 给OpenStack创建Win7镜像 Ceilometer的命令行使用 部署一个ceilometer-horizon项目 给OpenStack创建Windows XP镜像 几种企业的存储系统 概念模型、逻辑模型、物理模型的区别 五中常见的开源协议整理(BSD,Apache,GPL,LGPL,MIT) OpenStack监控项目Ceilometer的一些术语 VNC和远程桌面的区别 OpenStack Ceilometer项目简介 虚拟化与云计算中KVM,Xen,Qemu的区别和联系 调试和修改OpenStack中的Horizon部分 JavaScript变量作用域 kanyun worker原理 kanyun server服务 在OpenStack中部署kanyun kanyun的api-client命令 sae下的python开发部署和一个简单例子 OpenStack Nova内部机制【译】 PHP可变变量 JS中防止浏览器屏蔽window.open PHP操作Session的原理及提升安全性时的一个问题

标签


基于CSS3实现尖角面包屑

2013年12月08日

尖角面包屑导航应该算是比较常见的导航之一,尤其是在做流程引导的时候。为了做一个比较好看的导航,一般都会做成尖角的,而且还会有渐变色,这就是稍微麻烦点的地方了,下面是这个导航的一个实现原理

尖角实现

尖角的实现利用了CSS的before和after特性,以及无内容情况下border的特性,先来看看他们的介绍

伪元素before和after

before和after分别在一个元素前和后添加内容,使用方法如下:

a:before, a:after {
    content: "123";
}

这段的意思就是在a标签前后都增加了123文本,利用这个特性,可以给一个按钮前后都增加尖角了。

利用border实现尖角

border有一个特点,就是当元素内容是空的时候,border会占据内容的空间,效果点这里查看。

HTML代码:

<div class="bor"></div>

CSS代码:

.bor{
  width:0px;
  height:0px;
  border: solid;
  border-width: 20px 20px 20px 20px;
  border-color: red yellow green black; 
}

那么只要让before和after都变成这个样子,利用位置定位将这两部分分别移到相应位置,然后调整border某一边是透明就好了。

调整border透明

如果导航是纯色的,那么直接将before和after作为尖角即可,因为border可以设置纯色。但是如果想要给导航设置颜色渐变,那就只能通过设置导航来实现,border不能设置渐变色。这个时候只能通过将border设置的和背景色一致,遮挡导航主体部分来实现尖角特点。

最终效果

效果点这里查看。

HTML代码:

<div class="breadcrumbs">
  <div class="bread current"><a href="">test</a></div>
  <div class="bread"><a href="">test2</a></div>
</div>

CSS代码:

body{
  background:#D7D7D7;
}
.breadcrumbs{
  padding-left:40px;
  padding-top:7px;
}
.bread,.bread:hover{
  font-size:14px;
  display:inline;
  float:left;
  width:200px;
  background-color: #ddd;
  padding: 4px 10px 2px 0px;
  margin-right:40px;
  position: relative;
}
.bread{
  background-image: linear-gradient(to top, #F0F0F0, #F2F2F2);
}
.bread:hover{
  background-image: linear-gradient(to top, #EBE470, #F3F3EF); 
}
.current{
  background-image: linear-gradient(to top, #EBE470, #F3F3EF);
}
.bread > a{
  text-decoration: none;
  padding: 10px 10px 10px 40px;
}
.bread:hover > a{
  text-decoration: none;
  padding: 10px 10px 10px 40px;
}
.bread:before,.bread:after{
  content:"";
  border:solid;
  position: absolute;
  top:0px;
  border-width: 13px;
}
.bread:before{
  left:0px;
  border-color: transparent transparent transparent #D7D7D7;
}
.bread:after{
  right:0px;
  border-color: #D7D7D7 #D7D7D7 #D7D7D7 transparent;
}