2011-12-08 7 views
0

ここをクリックしてくださいデモ:http://web.cs.dal.ca/~selig/finale/jQueryの拡張ボタンがここで動作しないのはなぜですか?

これらは明らかに非常に奇妙に崩壊しています。誰も私がそれらを正しく無効にする方法を見つけ出すのを助けることができますか?

のjQuery:

$(document).ready(function() { 
    $('#toggle1').click(function() { 
     $('#collapse1').toggle('fast'); 
     $('#toggle1').attr('src', 'media/expand.png'); 
    }); 
    $('#toggle2').click(function() { 
     $('#collapse2').toggle('fast'); 
     $('#toggle2').attr('src', 'media/expand.png');  
    }); 
}); 

関連HTML:

このHTMLページのdivのセクションだけでなく、特定されたメニュー部分のためです。

<div id="menu"> 
       <ul> 
        <li class="title">Sites <img src="media/collapse.png" alt="Toggle expansion button" id="toggle1" /></li> 
       </ul> 
       <ul id="collapse1"> 
        <li><a href="">Assignment 1</a></li> 
        <li><a href="">Assignment 2</a></li> 
        <li><a href="">Assignment 3</a></li> 
        <li><a href="">Assignment 4</a></li> 
        <li><a href="">Assignment 5</a></li> 
        <li><a href="">Assignment 6</a></li> 
        <li><a href="">Assignment 7</a></li> 
       </ul> 

       <ul> 
        <li class="title">Articles <img src="media/collapse.png" alt="Toggle expansion button" id="toggle2" /></li> 
       </ul> 
       <ul id="collapse2"> 
        <li><a href="http://en.wikipedia.org/wiki/Christmas">Christmas</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Gift">Gifts</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Happiness">Happiness</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Santa_Claus">Santa Claus</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Rudolph_the_Red-Nosed_Reindeer">Rudolph</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Reindeer">Reindeer</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/December">December</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Snow">Snow</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Elf">Elves</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Christmas_carol">Caroling</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Christmas_card">Cards</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Eggnog">Eggnog</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Cookie">Cookies</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Chimney">Chimney</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Christmas_tree">Trees</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Christmas_lights_(decoration)">Lights</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Santa's_workshop">Workshop</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Gingerbread">Gingerbread</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Cheering">Cheer</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Tinsel"><strong>Tinsel</strong></a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Christmas_stocking">Stockings</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Gift_wrapping">Wrapping</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/The_Nutcracker">Nutcracker</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/World_of_Coca-Cola">Polar Bears</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Tatamagouche,_Nova_Scotia">T'was the night before Christmas</a></li> 
        <li><a href="http://en.wikipedia.org/wiki/Talladega_Nights:_The_Ballad_of_Ricky_Bobby">Baby Jesus</a></li> 
       </ul> 
      </div> 

関連するCSS:問題はul sはdisplay: inlineに設定されているという事実は、jQueryの.toggle()で行うことです

#menu { 
    float: left; 
    width: 107px; 
    background: tan; 
    color: black; 
    margin: 0 5px 0 0; 
    -webkit-border-radius: 3px; 
    -moz-border-radius: 3px; 
    border: 1px solid grey; 
    border-radius: 3px; 
} 

#menu ul { 
    display: inline; 
    list-style: none; 
    font-family: Helvetica, Arial, sans-serif; 
    font-size: 0.9em; 
} 

#menu li { 
    border-bottom: 1px solid black; 
    padding: 5px 5px 5px 5px; 
} 

#menu a { 
    color: black; 
} 

li.first { 
    border-left: 1px solid black; 
} 

li.title { 
    background: #593f26; 
    color: white; 
    text-align: center; 
    font-weight: bold; 
    text-transform: uppercase; 
} 
+0

GregLによると、問題はインラインブロックのプロパティです。とにかく、別のプロパティがjqueryの動作を混乱させている、このフィドルを参照してください:http://jsfiddle.net/sv3g4/ – Dave

答えて

2

(関連するHTML部分のCSS)メソッドは、表示するときにdisplay: inline-blockに設定します。

ブロックレベルの要素としてulが正しく表示されるようにCSSを微調整してから、jQueryの機能が動作するはずです。

関連する問題