2015-05-07 51 views
1

我使用這個:所有的CSS手風琴div的默認(無jQuery的)開放

jsfiddle.net/wromLbq5

,我希望能有擁有多個手風琴節一次打開的能力,並在頁面加載。我的意思是,當一個人打開時,我不希望另一個人關閉。這可能嗎?沒有JavaScript以及。

(忽略所有的子手風琴too-我只需要一層)

HTML

<ul class="accordion"> 

    <li id="one" class="files"> 
    <a href="#one">My Files<span>495</span></a> 
    <ul class="sub-menu"> 
     <li><a href="#one"><em>01</em>Dropbox<span>42</span></a></li> 
     <li><a href="#one"><em>02</em>Skydrive<span>87</span></a></li> 
     <li><a href="#one"><em>03</em>FTP Server<span>366</span></a></li> 
     <li><a href="#one"><em>01</em>Dropbox<span>42</span></a></li> 
     <li><a href="#one"><em>01</em>Dropbox<span>42</span></a></li> 
    </ul> 
    </li> 

    <li id="two" class="mail"> 
    <a href="#two">Mail<span>26</span></a> 
    <ul class="sub-menu"> 
     <li><a href="#two"><em>01</em>Hotmail<span>9</span></a></li> 
     <li><a href="#two"><em>02</em>Yahoo<span>14</span></a></li> 
     <li><a href="#two"><em>03</em>Gmail<span>3</span></a></li> 
    </ul> 
    </li> 

    <li id="three" class="cloud"> 
    <a href="#three">Cloud<span>58</span></a> 
    <ul class="sub-menu"> 
     <li><a href="#three"><em>01</em>Connect<span>12</span></a></li> 
     <li><a href="#three"><em>02</em>Profiles<span>19</span></a></li> 
     <li><a href="#three"><em>03</em>Options<span>27</span></a></li> 
    </ul> 
    </li> 

    <li id="four" class="sign"> 
    <a href="#four">Sign Out</a> 
    <ul class="sub-menu"> 
     <li><a href="#four"><em>01</em>Log Out</a></li> 
     <li><a href="#four"><em>02</em>Delete Account</a></li> 
     <li><a href="#four"><em>03</em>Freeze Account</a></li> 
    </ul> 
    </li> 

</ul> 

CSS

body {margin:50px;} 

/* Reset */ 
.accordion, 
.accordion ul, 
.accordion li, 
.accordion a, 
.accordion span { 
    margin: 0; 
    padding: 0; 
    border: none; 
    outline: none; 
} 
.accordion li { 
    list-style: none; 
} 

/* Layout & Style */ 
.accordion li > a { 
    display: block; 
    position: relative; 
    min-width: 110px; 
    padding: 0 10px 0 40px; 
    height: 32px; 

    color: #fdfdfd; 
    font: bold 12px/32px Arial, sans-serif; 
    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); 
} 

.accordion > li:hover > a, 
.accordion > li:target > a { 
    color: #3e5706; 
    text-shadow: 1px 1px 1px rgba(255,255,255, .2); 

    /*background: url(../img/active.png) repeat-x;*/ 
    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 > 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); 
} 


.accordion > li:hover > a span, 
.accordion > li:target > a span { 
    color: #fdfdfd; 
    text-shadow: 0px 1px 0px rgba(0,0,0, .35); 
    background: #3e5706; 
} 

/* Images */ 

.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(http://designmodo.com/demo/css3accordionmenu/img/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; } 

/* Sub Menu */ 

.sub-menu li a { 
    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:hover a { background: #efefef; } 

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

/* Functionality */ 

.accordion li > .sub-menu li { 
    height: 0; 
    overflow: hidden; 

    -webkit-transition: height .2s ease-in-out; 
    -moz-transition: height .2s ease-in-out; 
    -o-transition: height .2s ease-in-out; 
    -ms-transition: height .2s ease-in-out; 
    transition: height .2s ease-in-out; 
} 

.accordion li:target > .sub-menu li { 
    height: 33px; 
} 

我試圖避免任何Java腳本。 這可能嗎?

+1

總之,沒有。由於您的css使用':target'僞選擇器,開放手風琴是基於url並且一次只能有一個。要擁有多個打開狀態,您需要使用js。唯一的其他選擇是讓它們全部打開(刪除'height:0;'),但那不會是手風琴。 – Tims

+0

可以通過更改HTML和CSS來完成此操作。這雖然有點破綻。 –

回答

2

不,這是不可能的只有CSS,因爲你的例子使用CSS3 :target選擇器。當你點擊另一個項目時,目標會改變。

你不能用css設置狀態,但你可以設置它的樣式。如果你想保持每個部分打開後點擊你將不得不使用JavaScript,但你不需要jQuery

如果你想使用JavaScript,儘可能接近儘可能模仿CSS,同時允許手風琴繼續開放。要關閉手風琴,只需再次點擊標題即可。

var lists = document.querySelectorAll('.accordion > li > a'); // get list title links 
for (var i = 0; i < lists.length; i++) { // for each list title link 
    lists[i].href = "javascript:void()"; // stop the page from jumping 
    lists[i].onclick = function(e) { // when you click the link 
    var items = e.target.parentNode.querySelectorAll('li'); // get all list items that are siblings of the clicked link 
    for (var x = 0; x < items.length; x++) { // for each list item 
     if (items[x].style.height != '33px') { // if its not open 
     items[x].style.height = '33px'; // open it 
     } else { // otherwise 
     items[x].style.height = '0px'; // close it 
     } 
    } 
    }; 
} 

包裝這個腳本中的標籤,然後要麼在身體的底部掉它,或者在document.onload = function() { /* Script Here */ }

Demo)把它包

注意同時與:target任何風格選擇器將停止生效,如果用戶禁用了javascript,則應該將它們留在CSS中作爲後備。

+0

你能推薦JavaScript嗎?避免jQuery是理想的。謝謝! – jnapier

+0

(刪除了一些評論)我已經得到它的工作,但它討厭「href = javacscript」行,所以我已經崇拜回到href =「#一」等。沒有其他方式來避免'屏幕捕捉'在那兒?沒有在HTML中的JavaScript? – jnapier

1

這個CSS爲示出使用這種風格的全封閉的手風琴:

.accordion li > .sub-menu li { 
     height: 0px; 
    } 

你可以將它設置爲33px顯示所有打開的網頁打開時 - 但是,因爲它是會破壞功能:目標選擇器,然後設置高度,從而使選定部分顯示爲打開。

唯一的解決辦法是進入javascript .....

+0

你知道我可以使用的java嗎?但我必須避免使用jquery。任何想法都會很棒。 – jnapier

+0

@jnapier不使用Java,使用Javascript。他們不一樣。全部。記得Java對Javascript來說就像火腿對倉鼠! –

0

可以這樣做嗎?

您是否需要更改HTML?

它漂亮嗎?

基本上代替Target保持狀態。使用checkbox替代您的頂級a標籤與label

body {margin:50px;} 
 

 
/* Reset */ 
 
.accordion, 
 
.accordion ul, 
 
.accordion li, 
 
.accordion label, 
 
.accordion span { 
 
    margin: 0; 
 
    padding: 0; 
 
    border: none; 
 
    outline: none; 
 
} 
 
.accordion li { 
 
    list-style: none; 
 
} 
 

 
.accordion input[type="checkbox"]{display:none;} 
 

 
/* Layout & Style */ 
 
.accordion li > label, .accordion li > a { 
 
    display: block; 
 
    position: relative; 
 
    min-width: 110px; 
 
    padding: 0 10px 0 40px; 
 
    height: 32px; 
 

 
    color: #fdfdfd; 
 
    font: bold 12px/32px Arial, sans-serif; 
 
    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); 
 
} 
 

 
.accordion > li:hover > label, 
 
.accordion > li:target > label, 
 
.accordion > li > input[type="checkbox"]:checked ~ label{ 
 
    color: #3e5706; 
 
    text-shadow: 1px 1px 1px rgba(255,255,255, .2); 
 
    
 
    /*background: url(../img/active.png) repeat-x;*/ 
 
    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 > label 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); 
 
} 
 

 

 
.accordion > li:hover > label span, 
 
.accordion > li:target > label span, 
 
.accordion > li > input[type="checkbox"]:checked ~ label span{ 
 
    color: #fdfdfd; 
 
    text-shadow: 0px 1px 0px rgba(0,0,0, .35); 
 
    background: #3e5706; 
 
} 
 

 
/* Images */ 
 

 
.accordion > li > label:before { 
 
    position: absolute; 
 
    top: 0; 
 
    left: 0; 
 
    content: ''; 
 
    width: 24px; 
 
    height: 24px; 
 
    margin: 4px 8px; 
 

 
    background-repeat: no-repeat; 
 
    background-image: url(http://designmodo.com/demo/css3accordionmenu/img/icons.png); 
 
    background-position: 0px 0px; 
 
} 
 

 
.accordion li.files > label:before { background-position: 0px 0px; } 
 
.accordion li.files:hover > labe:before, 
 
.accordion li.files:target > label:before { background-position: 0px -24px; } 
 

 
.accordion li.mail > label:before { background-position: -24px 0px; } 
 
.accordion li.mail:hover > label:before, 
 
.accordion li.mail:target > label:before { background-position: -24px -24px; } 
 

 
.accordion li.cloud > label:before { background-position: -48px 0px; } 
 
.accordion li.cloud:hover > label:before, 
 
.accordion input[type="checkbox"]:checked:before { background-position: -48px -24px; } 
 

 
.accordion li.sign > label:before { background-position: -72px 0px; } 
 
.accordion li.sign:hover > label:before, 
 
.accordion input[type="checkbox"]:checked:before { background-position: -72px -24px; } 
 

 
/* Sub Menu */ 
 

 
.sub-menu li > a { 
 
    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:hover a { background: #efefef; } 
 

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

 
/* Functionality */ 
 

 
.accordion li > .sub-menu li { 
 
    height: 0; 
 
    overflow: hidden; 
 

 
    -webkit-transition: height .2s ease-in-out; 
 
    -moz-transition: height .2s ease-in-out; 
 
    -o-transition: height .2s ease-in-out; 
 
    -ms-transition: height .2s ease-in-out; 
 
    transition: height .2s ease-in-out; 
 
} 
 

 
.accordion input[type="checkbox"]:checked ~ .sub-menu li { 
 
    height: 33px; 
 
}
<ul class="accordion"> 
 
     
 
    <li id="one" class="files"> 
 
     <input type="checkBox" id="cbOne" checked="checked" /><label for="cbOne" >My Files<span>495</span></label> 
 
    <ul class="sub-menu"> 
 
     <li><a href="#one"><em>01</em>Dropbox<span>42</span></a></li> 
 
     <li><a href="#one"><em>02</em>Skydrive<span>87</span></a></li> 
 
     <li><a href="#one"><em>03</em>FTP Server<span>366</span></a></li> 
 
     <li><a href="#one"><em>01</em>Dropbox<span>42</span></a></li> 
 
     <li><a href="#one"><em>01</em>Dropbox<span>42</span></a></li> 
 
    </ul> 
 
    </li> 
 
    
 
    <li id="two" class="mail"> 
 
     <input type="checkBox" id="cbTwo" checked="checked" /><label for="cbTwo" >Mail<span>26</span></label> 
 
    <ul class="sub-menu"> 
 
     <li><a href="#two"><em>01</em>Hotmail<span>9</span></a></li> 
 
     <li><a href="#two"><em>02</em>Yahoo<span>14</span></a></li> 
 
     <li><a href="#two"><em>03</em>Gmail<span>3</span></a></li> 
 
    </ul> 
 
    </li> 
 
    
 
    <li id="three" class="cloud"> 
 
     <input type="checkBox" id="cbThree" checked="checked" /><label for="cbThree" >Cloud<span>58</span></label> 
 
    <ul class="sub-menu"> 
 
     <li><a href="#three"><em>01</em>Connect<span>12</span></a></li> 
 
     <li><a href="#three"><em>02</em>Profiles<span>19</span></a></li> 
 
     <li><a href="#three"><em>03</em>Options<span>27</span></a></li> 
 
    </ul> 
 
    </li> 
 
    
 
    <li id="four" class="sign"> 
 
     <input type="checkBox" id="cbFour" checked="checked" /><label for="cbFour" >Sign Out</label> 
 
    <ul class="sub-menu"> 
 
     <li><a href="#four"><em>01</em>Log Out</a></li> 
 
     <li><a href="#four"><em>02</em>Delete Account</a></li> 
 
     <li><a href="#four"><em>03</em>Freeze Account</a></li> 
 
    </ul> 
 
    </li> 
 

 
</ul>

看馬!沒有Javascript!