欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

純CSS3實現(xiàn)手風(fēng)琴風(fēng)格菜單具體步驟

  發(fā)布時間:2013-05-06 18:39:07   作者:佚名   我要評論
如何使用純CSS3創(chuàng)建手風(fēng)琴風(fēng)格菜單教程,菜單主要通過使用:target偽類來實現(xiàn),教程中我們主要通過使用偽類:before和:target來定義樣式,使用:target來實現(xiàn)菜單點擊展開子菜單事件。希望你能夠喜歡這個教程
今天分享一個如何使用純CSS3創(chuàng)建手風(fēng)琴風(fēng)格菜單教程,菜單主要通過使用:target偽類來實現(xiàn)。
:target使用介紹
CSS3 target偽類是眾多實用的CSS3特性中的一個。它用來匹配文檔(頁面)的URI中某個標(biāo)志符的目標(biāo)元素。具體來說,URI中的標(biāo)志符通常會包含一 個”#”字符,然后后面帶有一個標(biāo)志符名稱,比如#respond,target就是用來匹配ID為respond的元素的。
現(xiàn)在在頁面中,點擊一個ID鏈接后,頁面只會跳轉(zhuǎn)到相應(yīng)的位置,但是并不會有比較明顯的UI標(biāo)識,使用:target偽類可以像:hover等偽類一樣對目標(biāo)元素定義樣式。
第一步:HTML標(biāo)簽結(jié)構(gòu)
一 個簡單的無序列表,每個li中包含一個超鏈接和span,同時為每一個li添加一個不同的id和一個連接到這個id的超鏈接。為了添加樣式和展開菜單項下 面的內(nèi)容,需要使用:target偽類。

復(fù)制代碼
代碼如下:

<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">網(wǎng)盤<span>58</span></a></li>
<li id="four" class="sign"><a href="#four">退出登錄</a></li>
</ul>

第二步:菜單布局基本樣式
首先修改一些瀏覽器默認(rèn) 樣式,清除margin padding等等。

復(fù)制代碼
代碼如下:

.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%填充它的父元素,如果你想把菜單設(shè)置成300px,你可以給它添加一個父div,指定寬度為300px就可以了。雖然沒有指定寬度,但是定義 了最小寬度,保證菜單布局能夠正確的顯示。

復(fù)制代碼
代碼如下:

.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);
}

定義數(shù)字指示器樣式,當(dāng)然如果你的菜單不需要數(shù)字指示器,你打可以刪掉這個html結(jié)構(gòu)中 span元素。

復(fù)制代碼
代碼如下:

.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);
}

第三步:添加圖標(biāo)樣式
我們使用:before為菜單插入圖標(biāo),圖標(biāo)的寬 高都是24px,用下面的樣式使其正確的顯示。我創(chuàng)建了一個sprite,包含了四個圖標(biāo)的正常和hover時候的不同樣式。

復(fù)制代碼
代碼如下:

.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 -24px; }
.accordion li.mail > a:before { background-position: -24px 0px; }
.accordion li.mail:hover > a:before,
.accordion li.mail:target > a:before { background-position: -24px -24px; }
.accordion li.cloud > a:before { background-position: -48px 0px; }
.accordion li.cloud:hover > a:before,
.accordion li.cloud:target > a:before { background-position: -48px -24px; }
.accordion li.sign > a:before { background-position: -72px 0px; }
.accordion li.sign:hover > a:before,
.accordion li.sign:target > a:before { background-position: -72px -24px; }

第四步:子菜單HTML和樣式
HTML:
同 樣也使用ul作為子菜單,放到父菜單的li里面,如下代碼:

復(fù)制代碼
代碼如下:

<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:

復(fù)制代碼
代碼如下:

.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;
}

第五步:定義鼠標(biāo)懸浮和菜單激活時狀態(tài)樣式
當(dāng)鼠標(biāo)懸浮和菜單激活時改變 背景為綠色。

復(fù)制代碼
代碼如下:

.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; }

第六步:控制子菜單的顯示與隱藏
為 了隱藏子菜單,我們需要定義子菜單的高度為0px。當(dāng)點擊父菜單時,為子菜單添加下滑顯示的動態(tài)效果。為了實現(xiàn)下滑的效果,需要指定子菜單固定的高度。因 為這個教程中子菜單有三個link,所以這里指定了98px。如果你想加更多的子菜單就需要修改height為所有子菜單的高度和,當(dāng)然如果你想要讓它自 動變化,可以給高度賦值100%,但是這樣下滑的動畫效果就沒有了。

復(fù)制代碼
代碼如下:

.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;
}

總結(jié)
到此純CSS3實現(xiàn)的手風(fēng)琴風(fēng)格菜單就全部結(jié)束了。教程中我們主要通過使用偽類:before和:target來定義樣式,使用:target來實現(xiàn)菜單點擊展開子菜單事件。希望你能夠喜歡這個教程。

相關(guān)文章

  • 超酷炫 CSS3垂直手風(fēng)琴菜單

    這篇文章主要為大家詳細(xì)介紹了一款非常炫酷的CSS3垂直手風(fēng)琴菜單,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-06-28
  • CSS3實現(xiàn)可關(guān)閉的下拉手風(fēng)琴菜單效果

    這篇文章主要為大家介紹了CSS3實現(xiàn)可關(guān)閉的下拉手風(fēng)琴菜單效果,采用純css3技術(shù)實現(xiàn)了手風(fēng)琴折疊與展開效果,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-08-31
  • 用純CSS實現(xiàn)手風(fēng)琴效果的示例代碼

    這篇文章主要介紹了用純CSS實現(xiàn)手風(fēng)琴效果的示例代碼的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-28

最新評論