前端开发者学堂 - fedev.cn

藤藤每日一练——CSS3 Admin Menu

发布于 藤藤

这一个个人信息面板导航效果,整个效果展示的是个人相关信息的菜单项,以及搜索功能。在这个案例中使用的CSS3属性相对较多,有transition做的过渡动画效果、有transform做的3D旋转动画、@font-face实现的icon效果,gradient制作的双色块导航背景。而其中运用的最好的是CSS3的选择器,整个案例中使用了多个CSS3选择器,来控制需要选择的元素,比如说“:not”选择器,“nth-children()“选择器,详细的请看Demo的整个实现过程。

demodownload

HTML CODE

结构很简单,就是一个无序列表:

<div class="page-menu-wrapper">
  <ul class="menu-function clearfix">
    <li><a href="" title="">Home</a></li>
    <li>
      <a href="javascript:;" title="">Search
        <div class="drop-down">
          <input type="text" name="" id="" placeholder="best psd freebies">
          <button type="button"></button>
        </div>
      </a>
    </li>
    <li><a href="" title="">Inbox <span>2</span></a></li>
    <li><a href="" title="">Add New</a></li>
    <li><a href="" title="">Updates <span>8</span> </a></li>
    <li><a href="" title="">Howdy <span>Eva.</span><img src="x.jpg" alt="Eva."></a></li>
  </ul>
</div>

不同之处是,在搜索菜单项中,还有一个下拉结构

<li>
  <a href="javascript:;" title="">Search
  <div class="drop-down">
    <input type="text" name="" id="" placeholder="best psd freebies">
    <button type="button"></button>
  </div>
  </a>
</li>

和平时制作下拉菜单效果的结构略有不同,这个案例中,将整个搜索表单放在了链接<a>标签内。

CSS3 CODE

整个案例的CSS代码并不复杂,只是CSS3的选择器使用的稍为多一些。我们一步一步来看:

body {
  background-color: #d9d9d9;
}
a {
  color: #fff;
}
a:hover {
  color: #fff;
  text-decoration: none;
} 
.demo {
  width: 960px;
  margin: 40px auto 0;
}
.menu-function {
  position: relative;
  background-image: -*-linear-gradient(top,#3d3d3d 50%,#373737 51%);/*制作双色块背景图片*/
}
.menu-function li {
  float: left;
  height: 40px;
}
.menu-function li a {
  position: relative;
  display: block;
  padding: 0 20px 0 40px;
  line-height: 40px;
}

这部分代码是用来实现导航的初步布局效果,整个效果之中,使用了gradient渐变属性制作了一个双色块的背景图片:

 background-image: -*-linear-gradient(top,#3d3d3d 50%,#373737 51%);

注意,这是从上到下的双色块,第一个色是多0到50%之间,第二个色块是51%到100%之间。

/*设置除最后一个列表项下的所有span元素的样式*/
.menu-function li:not(:last-child) span {
  display: inline-block;
  padding: 0 3px;
  height: 14px;
  line-height: 14px;
  color: #fff;
  border-radius: 2px;/*设置圆角*/
  box-shadow: 0 -1px 0 #6cb6e9,0 1px 0 #24548e;/*设置阴影*/
  background-image: -*-linear-gradient(top,#2b95e0,#2175d7);/*设置渐变背景*/
}
/*设置除最后一个列表项下的所有a元素样式*/
.menu-function li:not(:last-child) a {
  line-height: 20px;
  border-left: 1px solid #222a30;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  transition: all .3s ease-out;/*设置动画过渡效果*/
  transform-style: preserve-3d;/*设置3D旋转遮照面*/
}

这里就有点意思了,意思之处是他的选择器”li:not(:last-child)“,他表示的意思是”选择除最后一个列表项的所有列表项“

/*最后一个列表向右浮动*/
.menu-function li:last-child {
  float: right;
}
/*设置第一个列表项下a元素样式*/
.menu-function li:first-child a {
  font-size: 0;
  padding-left: 25px;
}
/*设置最后一个列表项下img元素样式*/
.menu-function li:last-child img {
  width: 30px;
  height: 30px;
  margin-left: 2px;
  vertical-align: middle;
  box-shadow: 0 -1px 0 rgba(0,0,0,.2);/*设置阴影*/
  border-radius: 2px;/*设置圆角*/
}
/*设置最后一个列表项下span元素样式*/
.menu-function li:last-child span {
  color: #a3c8ea;
}

这几个选择器应该很容易理解,就是第一元素和最后一个元素的伪类选择器。

.menu-function li a:before,
.drop-down button[type="button"]:before {
  position: absolute;
  left: 15px;
  font-family: 'icomoon';
  font-style: normal;
  speak: none;
  font-weight: normal;
  font-smoothing: antialiased;
  font-size: 18px;
  vertical-align: middle;
} 
.menu-function li:nth-child(1) a:before {
  content: "\21";/*代表首页的icon*/
}
.menu-function li:nth-child(2) a:before,
.drop-down button[type="button"]:before {
  content: "\7d";/*代表搜索放大器的icon*/
}
.menu-function li:nth-child(3) a:before {
  content: "\63";/*代表评论信息的icon*/
}
.menu-function li:nth-child(4) a:before {
  content: "\e022";/*代表google plus的icon*/
}
.menu-function li:nth-child(5) a:before {
  content: "\38";/*代表文件夹的icon*/
}

这里是通过伪类”:before“配合@font-face属性制作的字体icon。在这里我们使用了”icomoon“字体,至于这个字体哪来的,我们在前而有整理过,这里不在多说。可能大家会问,代表icon的编号是怎么来的,这个在字体库有一个对照表,可以查询出对应的icon编号,至于这样的编号是怎么来的,说实话我也不清楚,只有设计者知道。另外这里还使用了”nth-child“选择器,来选择不同的列表项下的a元素。当然,使用这个关键之处还有@font-face调用服务器上的字体库:

@font-face {
  font-family: 'icomoon';
  src:url('fonts/icomoon.eot');
  src:url('fonts/icomoon.eot?#iefix') format('embedded-opentype'),
    url('fonts/icomoon.svg#icomoon') format('svg'),
    url('fonts/icomoon.woff') format('woff'),
    url('fonts/icomoon.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

这个很关键了。没有font-face是无法实现icon的效果。

.menu-function li:not(:last-child) a:hover {
  color: #555;
  border-left: 1px solid transparent;
  background-color: #fff;
}

设置除最后一个列表项下所有a元素的样式,使用的选择器方法前面有介绍过。

/*设置搜索列表项悬浮时下拉搜索表单样式*/
.menu-function li a:hover .drop-down {
  display: block;
  transform: rotateX(0deg);/*X轴旋转odeg*/
}
/*设置下接搜索表单样式*/
.drop-down {
  position: absolute;
  top: 30px;
  left: 0;
  margin-left: -1px;
  width: 300px;
  padding: 20px; 
  background-color: #fff;
  transition: all 0.3s ease-in;/*过渡动画效果*/
  transform: rotateX(-90deg);/*X轴旋转-90deg*/
  backface-visibility: hidden;
}
/*设置文本框样式*/
.drop-down input[type="text"] {
  width: 100%;
  height: 30px;
  padding-left: 5px;
  border: 1px solid #ddd;
  border-radius: 2px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.2) inset;/*设置阴影*/
  background-color: none;
  box-sizing: border-box;/*改变盒模型*/
  transition: all 0.3s ease-in;/*过渡动画效果*/
}
/*设置搜索按钮样式*/
.drop-down button[type="button"] {
  position: absolute;
  top: 22px;
  right: 22px;
  width: 24px;
  height: 26px;
  border: none;
  background-color: transparent;
}
.drop-down button[type="button"]:before {
  font-size: 14px;
  top: 6px;
  left: 6px;
  color: #747474;
}
input[type="text"]:focus{
  outline: 0 none;
  border-color: rgba(82, 168, 236, 0.8);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1), 0 0 8px rgba(82, 168, 236, 0.6);
}

整个搜索表单使用了transform、transition、box-shadow等属性制作,其中还使得了属性选择器来控制表单元素的样式。

整个案例的CSS代码:

body {
  background-color: #d9d9d9;
}
a {
  color: #fff;
}
a:hover {
  color: #fff;
  text-decoration: none;
} 
.demo {
  width: 960px;
  margin: 40px auto 0;
}
.menu-function {
  position: relative;
  background-image: -*-linear-gradient(top,#3d3d3d 50%,#373737 51%);
}
.menu-function li {
  float: left;
  height: 40px;
}
.menu-function li a {
  position: relative;
  display: block;
  padding: 0 20px 0 40px;
  line-height: 40px;
}
.menu-function li:not(:last-child) span {
  display: inline-block;
  padding: 0 3px;
  height: 14px;
  line-height: 14px;
  color: #fff;
  border-radius: 2px;
  box-shadow: 0 -1px 0 #6cb6e9,0 1px 0 #24548e;
  background-image: -*-linear-gradient(top,#2b95e0,#2175d7);
}
.menu-function li:not(:last-child) a {
  line-height: 20px;
  border-left: 1px solid #222a30;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  transition: all .3s ease-out;
  transform-style: preserve-3d;
}
.menu-function li:last-child {
  float: right;
}
.menu-function li:first-child a {
  font-size: 0;
  padding-left: 25px;
}
.menu-function li:last-child img {
  width: 30px;
  height: 30px;
  margin-left: 2px;
  vertical-align: middle;
  box-shadow: 0 -1px 0 rgba(0,0,0,.2);
  border-radius: 2px;
}
.menu-function li:last-child span {
  color: #a3c8ea;
}
.menu-function li a:before,.drop-down button[type="button"]:before {
  position: absolute;
  left: 15px;
  font-family: 'icomoon';
  font-style: normal;
  speak: none;
  font-weight: normal;
  font-smoothing: antialiased;
  font-size: 18px;
  vertical-align: middle;
} 
.menu-function li:nth-child(1) a:before {
  content: "\21";
}
.menu-function li:nth-child(2) a:before,.drop-down button[type="button"]:before {
  content: "\7d";
}
.menu-function li:nth-child(3) a:before {
  content: "\63";
}
.menu-function li:nth-child(4) a:before {
  content: "\e022";
}
.menu-function li:nth-child(5) a:before {
  content: "\38";
}
.menu-function li:not(:last-child) a:hover {
  color: #555;
  border-left: 1px solid transparent;
  background-color: #fff;
}
.menu-function li a:hover .drop-down {
  display: block;
  transform: rotateX(0deg);
}
.drop-down {
  position: absolute;
  top: 30px;
  left: 0;
  margin-left: -1px;
  width: 300px;
  padding: 20px; 
  background-color: #fff;
  transition: all 0.3s ease-in;
  transform: rotateX(-90deg);
  backface-visibility: hidden;
}
.drop-down input[type="text"] {
  width: 100%;
  height: 30px;
  padding-left: 5px;
  border: 1px solid #ddd;
  border-radius: 2px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.2) inset;
  background-color: none;
  box-sizing: border-box;
  transition: all 0.3s ease-in;
}
.drop-down button[type="button"] {
  position: absolute;
  top: 22px;
  right: 22px;
  width: 24px;
  height: 26px;
  border: none;
  background-color: transparent;
}
.drop-down button[type="button"]:before {
  font-size: 14px;
  top: 6px;
  left: 6px;
  color: #747474;
}
input[type="text"]:focus{
  outline: 0 none;
  border-color: rgba(82, 168, 236, 0.8);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1), 0 0 8px rgba(82, 168, 236, 0.6);
}
@font-face {
  font-family: 'icomoon';
  src:url('fonts/icomoon.eot');
  src:url('fonts/icomoon.eot?#iefix') format('embedded-opentype'),
    url('fonts/icomoon.svg#icomoon') format('svg'),
    url('fonts/icomoon.woff') format('woff'),
    url('fonts/icomoon.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

demodownload

如需转载,烦请注明出处:https://www.fedev.cn/demo/css3-admin-menu.html

jordan shoes for sale outlet trainers