11

私はjQueryが初めてです。プロジェクトに検索ボックス機能を作成しようとしています。都市の名前を含む div を作成し、ボタンのクリック イベントに表示したいと考えています。slideToggle()ボタンのクリックイベントでjQueryのメソッドを使用して、そのdivを非表示および表示できます。しかし、div が表示されると、自分のページの他のコンテンツが気になってしまいます。私はこの動作を期待していません。

そのdivを表示する前の私の画像は次のとおりです。

ここに画像の説明を入力

以下は、div が表示された後のページのイメージです。

ここに画像の説明を入力

ここで、この div をポップアップのように表示して、ページの他のコンテンツの邪魔にならないようにしたいと考えています。

以下は、HTML の検索ボックス セクションのコードです。

        <!--start SearchBox section-->
        <section id="searchbox"style="background:white">
            <div class="container" style="margin-top:0px;">


              <div class="row">

                    <div class="col-lg-12">


               <form style="">
                    <center>
                            <div id="SearchBoxBorder" style="background:white;border:2px solid #a1a1a1;border-radius:5px;margin-top:20px;width:800px;">
                            <table id="mytable" >
                                    <td style="width:300px;background:white;">
                                       <center> <div class="form-group">
                                                <input type="text" class="form-control" id="exampleInputEmail1" placeholder="I am looking for"
                                                    style="border-width:5px;background:white; margin-top:17px; margin-left:15px; margin-right:10px;width:300px;
                                                    border-style:solid;border-width:5px;border-color:#a1a1a1;font-family:Arial,Helvetica,sans-serif;height:42px; font-size:18px;">
                                        </div></center>
                                     </td>

                                     <td style="width:50px ;text-align:right;background:white;"> <center><strong> in</strong></center>    </td>

                                     <td style="width:400px;background:white;">
                                     <center>
                                             <div class="input-group">
                                                   <input type="text" class="form-control" placeholder="in locality"
                                                    style="border-width:5px;background:white; margin-top:0px; margin-left:10px; margin-right:20px;width:;font-size:18px;
                                                    border-style:solid;border-width:5px;border-color:#a1a1a1;font-family:Arial,Helvetica,sans-serif;height:42px;">
                                                   <div class="input-group-btn">
                                                            <button type="button" class="btn btn-default dropdown-toggle"  data-toggle="dropdown" id="dropdownBtn" 
                                                             style="background:white;border-top-width:5px;border-right-width:5px;border-bottom-width:5px;border-left-width:1px;
                                                             border-color:#a1a1a1;height:42px;border-radius:0px;text-align:center;color:black; margin-right:20px;">Select<span class="caret"></span></button>

                                                             <!--City dropdown -->
                                                                    <div class="SearchCities">
                                                                            <div id="outer" style="">



                                                                                        <div id="innerLeft" style="">
                                                                                            <h5 >North India:</h5>
                                                                                            <ul class="city" type="none";>
                                                                                                    <li><a>Delhi</a></li>
                                                                                                    <li><a>Agra</a></li>
                                                                                                    <li><a>Shrinagar</a></li>
                                                                                                    <li><a>Noida</a></li>
                                                                                                    <li><a>Himachal</a></li>
                                                                                                    <li><a>Patna</a></li>
                                                                                            </ul>

                                                                                        </div>

                                                                                        <div id="innerRight" style="">
                                                                                            <a class="close">&times;</a>
                                                                                            <h5>West India:</h5>
                                                                                            <ul class="city" type="none";>
                                                                                                    <li><a>Mumbai</a></li>
                                                                                                    <li><a>Pune</a></li>
                                                                                                    <li><a>Nashik</a></li>
                                                                                                    <li><a>Kolhapur</a></li>
                                                                                                    <li><a>Osmanabad</a></li>
                                                                                                    <li><a>Ahamdabad</a></li>
                                                                                            </ul>
                                                                                        </div>


                                                                            </div><!--/outer-->
                                                                        </div><!--/SearchCities-->


                                                             </div><!-- /btn-group -->
                                                   <button type="button" class="btn btn-primary" style="margin-right:20px;"><i class="icon-search" style="font-size:20px"></i>  Search</button>
                                             </div><!-- /input-group -->
                                           </center>         
                                     </td>

                            </table>
                        </center>
                    </form>

    </div><!--/col-lg-12-->
</div><!--/row-->
    </div><!--/end of container-->
</section>
<!--End of SearchBox section-->

以下は私のjQueryコードです:

$(document).ready(function(){
  $(".SearchCities").hide();
  $("#dropdownBtn").click(function(){
  $(".SearchCities").slideToggle();
  });
});

私がやりたいことの詳細については、 askme.comにアクセスして、上部の検索ボックスを参照し、インドの残りをクリックしてください。それで、これを達成するのを手伝ってもらえますか?前もって感謝します。

4

3 に答える 3

11

基本的に次の 3 つの方法があります。

  1. 手で:ポップアップ div をフローティングにして絶対位置に配置し、次に top を 100% に設定します (これにより、ポップアップ メニューのように見えます。親要素に相対位置があることを確認してください。

    HTML:

    <div class="input-group" style="position: relative;">
      <div class="SearchCities">
        ...
      </div>
    </div>
    

    CSS:

    .SearchCities {
      float: right;
      position: absolute;
      top: 100%;
    }
    

    JS: 変更不要

  2. jQueryUI のダイアログ プラグインを使用する: nrsharma の回答で指摘されているように、jQuery プラグインを使用してポップアップ ダイアログのように見せることができます。

    $('.SearchCities').dialog({ autoOpen: false }); // Initialize dialog plugin
    $('.SearchCities').dialog("open"); // Open popup
    

    API リファレンス: http://api.jqueryui.com/dialog/

    例: http://jqueryui.com/dialog/

    プラグインのダウンロード: http://jqueryui.com/download/

  3. Bootstrap のドロップダウン コンポーネントを使用します。コードから、bootstrap を使用しているように見えます。ブートストラップ ドロップダウンまたはモーダルを簡単に使用できます。

    ブートストラップ モーダルは、jQueryUI のダイアログ プラグインと同様のポップアップ ダイアログですが、見栄えがよく、カスタマイズ性がはるかに優れています。例については、http: //getbootstrap.com/javascript/#modalsをご覧ください。

    Bootstrap ドロップダウンは単純なドロップダウン メニューですが、少しハッキングすれば、何でも入れることができます。

    必要なのは少しの HTML だけです (JavaScript は必要ありません):

    <div class="input-group dropdown">
      <button type="button" class="btn btn-default dropdown-toggle"
        data-toggle="dropdown" id="dropdownBtn" role="button">...</button>
      <div class="dropdown-menu SearchCities" role="menu">
        ...
      </div>
    </div>
    

    これを機能させるには、Bootstrap js プラグイン (bootstrap.js/bootstrap.min.js) も含める必要があります。

    参照: http://getbootstrap.com/javascript/#dropdowns

于 2013-10-12T12:11:52.483 に答える
3

jQuery UI ダイアログで簡単に実行できます。

HTML:

<div id="dialog" title="Basic dialog">
  <p>This is the default dialog which is useful for displaying information. The
     dialog window can be moved, resized and closed with the 'x' icon.</p>
</div>

JavaScript/jQuery:

$(function() {
    $( "#dialog" ).dialog();
});

詳細については、こちらをご覧ください

于 2013-10-12T11:59:13.050 に答える