纯CSS3完成手风琴设计风格菜单实际流程

日期:2021-03-10 类型:科技新闻 

关键词:在线网页制作,建网页,个人简介网页制作,简单网页,建立网页

今日共享1个怎样应用纯CSS3建立手风琴设计风格菜单实例教程,菜单关键根据应用:target伪类来完成。
:target应用详细介绍
CSS3 target伪类是诸多好用的CSS3特点中的1个。它用来配对文本文档(网页页面)的URI中某个标示符的总体目标元素。实际来讲,URI中的标示符一般会包括1 个”#”标识符,随后后边带有1个标示符名字,例如#respond,target便是用来配对ID为respond的元素的。
如今在网页页面中,点一下1个ID连接后,网页页面只会自动跳转到相应的部位,可是其实不会有较为显著的UI标志,应用:target伪类能够像:hover等伪类1样对总体目标元素界定款式。
第1步:HTML标识构造
1 个简易的无编码序列表,每一个li中包括1个超连接和span,另外为每个li加上1个不一样的id和1个联接到这个id的超连接。以便加上款式和进行菜单项下 面的內容,必须应用:target伪类。

拷贝编码
编码以下:

<ul class="accordion">
<li id="one" class="files"><a href="#one">我的文档<span>495</span></a></li>
<li id="two" class="mail"><a href="#two">电子邮件<span>26</span></a></li>
<li id="three" class="cloud"><a href="#three">网盘<span>58</span></a></li>
<li id="four" class="sign"><a href="#four">撤出登陆</a></li>
</ul>

第2步:菜单合理布局基础款式
最先改动1些访问器默认设置 款式,消除margin padding这些。

拷贝编码
编码以下:

.accordion,
.accordion ul,
.accordion li,
.accordion a,
.accordion span {
margin: 0;
padding: 0;
border: none;
outline: none;
text-align:left;
}
.accordion li {
list-style: none;
}

界定菜单项连接款式,加上渐变色,黑影的实际效果,界定字体样式等。这里沒有特定固定不动的宽度,菜单的 宽度100%填充它的父元素,假如你想把菜单设定成300px,你能够给它加上1个父div,特定宽度为300px便可以了。尽管沒有特定宽度,可是界定 了最少宽度,确保菜单合理布局可以正确的显示信息。

拷贝编码
编码以下:

.accordion li > a {
display: block;
position: relative;
min-width: 110px;
padding: 0 10px 0 40px;
color: #fdfdfd;
font: bold 14px/32px 黑体,宋体;
text-decoration: none;
text-shadow: 0px 1px 0px rgba(0,0,0, .35);
background: #6c6e74;
background: -moz-linear-gradient(top, #6c6e74 0%, #4b4d51 100%);
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#6c6e74), color-stop(100%,#4b4d51));
background: -webkit-linear-gradient(top, #6c6e74 0%,#4b4d51 100%);
background: -o-linear-gradient(top, #6c6e74 0%,#4b4d51 100%);
background: -ms-linear-gradient(top, #6c6e74 0%,#4b4d51 100%);
background: linear-gradient(top, #6c6e74 0%,#4b4d51 100%);
-webkit-box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
-moz-box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
}

界定数据标示器款式,自然假如你的菜单不必须数据标示器,你打能够删除这个html构造中 span元素。

拷贝编码
编码以下:

.accordion li > a span {
display: block;
position: absolute;
top: 7px;
right: 0;
padding: 0 10px;
margin-right: 10px;
font: normal bold 12px/18px Arial, sans-serif;
background: #404247;
-webkit-border-radius: 15px;
-moz-border-radius: 15px;
border-radius: 15px;
-webkit-box-shadow: inset 1px 1px 1px rgba(0,0,0, .2), 1px 1px 1px rgba(255,255,255, .1);
-moz-box-shadow: inset 1px 1px 1px rgba(0,0,0, .2), 1px 1px 1px rgba(255,255,255, .1);
box-shadow: inset 1px 1px 1px rgba(0,0,0, .2), 1px 1px 1px rgba(255,255,255, .1);
}

第3步:加上标志款式
大家应用:before为菜单插进标志,标志的宽 高全是24px,用下面的款式使其正确的显示信息。我建立了1个sprite,包括了4个标志的一切正常和hover情况下的不一样款式。

拷贝编码
编码以下:

.accordion > li > a:before {
position: absolute;
top: 0;
left: 0;
content: '';
width: 24px;
height: 24px;
margin: 4px 8px;
background-repeat: no-repeat;
background-image: url(../images/icons.png);
background-position: 0px 0px;
}
.accordion li.files > a:before { background-position: 0px 0px; }
.accordion li.files:hover > a:before,
.accordion li.files:target > a:before { background-position: 0px ⑵4px; }
.accordion li.mail > a:before { background-position: ⑵4px 0px; }
.accordion li.mail:hover > a:before,
.accordion li.mail:target > a:before { background-position: ⑵4px ⑵4px; }
.accordion li.cloud > a:before { background-position: ⑷8px 0px; }
.accordion li.cloud:hover > a:before,
.accordion li.cloud:target > a:before { background-position: ⑷8px ⑵4px; }
.accordion li.sign > a:before { background-position: ⑺2px 0px; }
.accordion li.sign:hover > a:before,
.accordion li.sign:target > a:before { background-position: ⑺2px ⑵4px; }

第4步:子菜单HTML和款式
HTML:
同 样也应用ul做为子菜单,放到父菜单的li里边,以下编码:

拷贝编码
编码以下:

<li id="one"><a href="#one">我的文档<span>495</span></a>
<ul>
<li><a href="javascript:void(0);"><em>01</em>歌曲<span>42</span></a></li>
<li><a href="javascript:void(0);"><em>02</em>视頻<span>87</span></a></li>
<li><a href="javascript:void(0);"><em>03</em>照片<span>366</span></a></li>
</ul>
</li>

CSS:

拷贝编码
编码以下:

.sub-menu li a {
font: bold 12px/32px 黑体,宋体;
color: #797979;
text-shadow: 1px 1px 0px rgba(255,255,255, .2);
background: #e5e5e5;
border-bottom: 1px solid #c9c9c9;
-webkit-box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
-moz-box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
}
.sub-menu li:last-child a { border: none; }
.sub-menu li > a span {
color: #797979;
text-shadow: 1px 1px 0px rgba(255,255,255, .2);
background: transparent;
border: 1px solid #c9c9c9;
-webkit-box-shadow: none;
-moz-box-shadow: none;
box-shadow: none;
}
.sub-menu em {
position: absolute;
top: 0;
left: 0;
margin-left: 14px;
color: #a6a6a6;
font: normal 10px/32px Arial, sans-serif;
}

第5步:界定电脑鼠标飘浮和菜单激活时情况款式
当电脑鼠标飘浮和菜单激活时更改 情况为翠绿色。

拷贝编码
编码以下:

.accordion > li:hover > a,
.accordion > li:target > a {
color: #3e5706;
text-shadow: 1px 1px 1px rgba(255,255,255, .2);
background: #a5cd4e;
background: -moz-linear-gradient(top, #a5cd4e 0%, #6b8f1a 100%);
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#a5cd4e), color-stop(100%,#6b8f1a));
background: -webkit-linear-gradient(top, #a5cd4e 0%,#6b8f1a 100%);
background: -o-linear-gradient(top, #a5cd4e 0%,#6b8f1a 100%);
background: -ms-linear-gradient(top, #a5cd4e 0%,#6b8f1a 100%);
background: linear-gradient(top, #a5cd4e 0%,#6b8f1a 100%);
}
.accordion > li:hover > a span,
.accordion > li:target > a span {
color: #fdfdfd;
text-shadow: 0px 1px 0px rgba(0,0,0, .35);
background: #3e5706;
}
.sub-menu li:hover a { background: #efefef; }

第6步:操纵子菜单的显示信息与掩藏
为 了掩藏子菜单,大家必须界定子菜单的高宽比为0px。当点一下父菜单时,为子菜单加上下滑显示信息的动态性实际效果。以便完成下滑的实际效果,必须特定子菜单固定不动的高宽比。因 为这个实例教程中子菜单有3个link,因此这里特定了98px。假如你想加更多的子菜单就必须改动height为全部子菜单的高宽比和,自然假如你要想让它自 动转变,能够给高宽比取值100%,可是这样下滑的动漫实际效果就沒有了。

拷贝编码
编码以下:

.accordion li > .sub-menu {
height: 0;
overflow: hidden;
-webkit-transition: all .2s ease-in-out;
-moz-transition: all .2s ease-in-out;
-o-transition: all .2s ease-in-out;
-ms-transition: all .2s ease-in-out;
transition: all .2s ease-in-out;
}
.accordion li:target > .sub-menu {
height: 98px;
}

总结
到此纯CSS3完成的手风琴设计风格菜单就所有完毕了。实例教程中大家关键根据应用伪类:before和:target来界定款式,应用:target来完成菜多点击进行子菜单恶性事件。期待你可以喜爱这个实例教程。
上一篇:怎样提升手机上网站 返回下一篇:没有了