2

Bootstrap を使用しており、ボタンがクリックされたときにドロップダウン メニューでイベントを宣言しようとしています。奇妙な理由で、jquery イベントがトリガーされません。ドロップダウン メニューは、検索クエリ要素のすぐ下にドロップダウンする必要があります。私の JS Fiddle はhttp://jsfiddle.net/sean3200/fNrZ3/です ...どんな助けでも大歓迎です..Thankzz!! 以下はコードの一部です

     <div class="container">
  <div class="navbar">
    <div class="navbar-inner">
      <div class="container">
        <a class="btn btn-navbar" data-toggle="collapse" data-target=".nav-collapse">
    <span class="icon-bar"></span>
    <span class="icon-bar"></span>
    <span class="icon-bar"></span>
  </a>
        <a class="brand" href="#">Forbes Clientel</a>
        <div class="nav-collapse collapse">
          <ul class="nav">
            <li>
              <a href="#" class="active">Home</a> 
            </li>
            <li>
              <a href="#">Contact</a> 
            </li>
          </ul>
        </div>
        <form class="navbar-search">
          <input class="search-query" placeholder="Search..." type="text">
          <div id="drop" class="dropdown">
            <ul class="dropdown-menu" role="menu" aria-labelledby="dLabel">
              <li>
                <a tabindex="-1" href="#">Action</a> 
              </li>
              <li>
                <a tabindex="-1" href="#">Another action</a> 
              </li>
              <li>
                <a tabindex="-1" href="#">Something else here</a> 
              </li>
              <li class="divider"></li>
              <li>
                <a tabindex="-1" href="#">Separated link</a> 
              </li>
            </ul>
          </div>
        </form>
      </div>
    </div>
  </div>
  <div class="container">
    <div class="hero-unit">
      <h1>Forbes Clientel</h1>
      <p>FC is a directory of the top forbes earning entrepreneurs</p>
      <input id="myBtn"
      class="btn btn-primary btn-large" value="Search" type="button"> 
    </div>
  </div>
</div>


//script
             $(document).ready(function(){
                $("#myBtn").click(function(){
                  $("#drop").slidedown();
                })

             })
4

3 に答える 3

1

エリラン・エフロンが言ったように、JS の 3 行目を次のように変更します。

$("#drop").slideDown();

HTML の 25 ~ 26 行目を次のように変更します。

<div class="dropdown">
  <ul id="drop" class="dropdown-menu" role="menu" aria-labelledby="dLabel">

JS で間違った要素を参照していました。それだけです。

変更されて機能している例を次に示します: http://jsfiddle.net/fNrZ3/4/

于 2013-06-02T20:26:37.887 に答える
1

最初に: 関数は.slideDown() 大文字の d という名前で、大きな変更を加えることができます... (機能しているかどうかにかかわらず、呼び出している関数であることを忘れないでください)。

クロムの JS コンソールで見たものから、エラーが表示されます。Uncaught TypeError: Object [object Object] has no method 'slidedown'名前に関係があることは間違いないので、大文字の D.

そこからは、主にデザインの設定だと思います...デモでここを見て、その一部を使用してみてください: .slideDown() jQuery API

于 2013-06-02T19:29:54.643 に答える
1
$(document).ready(function($){
    $('.dropdown-menu').click(function(e) {
        e.stopPropagation();
    });
    $(".btn-group").click(function(){
        if($(this).hasClass('open')){
            $(".dropdown-menu").slideUp();
        }else{
            $(".dropdown-menu").slideDown();
        }
    });    
});

$(document).on('click.dropdown.data-api', function(){
        $(".dropdown-menu").slideUp();
});
于 2013-07-21T12:07:13.323 に答える