私は自分のアプリケーションで次のようにブートストラップDropdownコンポーネントを使用しています。
<div class="btn-group">
<button class="btn">Please Select From List</button>
<button class="btn dropdown-toggle" data-toggle="dropdown">
<span class="caret"></span>
</button>
<ul class="dropdown-menu" role="menu" aria-labelledby="dropdownMenu">
<li><a tabindex="-1" href="#">Item I</a></li>
<li><a tabindex="-1" href="#">Item II</a></li>
<li><a tabindex="-1" href="#">Item III</a></li>
<li class="divider"></li>
<li><a tabindex="-1" href="#">Other</a></li>
</ul>
</div>
選択したアイテムをBTNラベルとして表示します。つまり、「一覧から選択してください」を選択したリスト項目(「項目I」、「項目II」、「項目III」)に置き換えます。
私があなたの問題を理解している限りでは、リンクされたテキストをクリックしてボタンのテキストを変更したいというのであれば、あなたはこれを試すことができます: /4 /編集
$(function(){
$(".dropdown-menu li a").click(function(){
$(".btn:first-child").text($(this).text());
$(".btn:first-child").val($(this).text());
});
});
あなたのコメントに従って:
これは私がリスト項目<li>
をajax呼び出しを通して追加したときにはうまくいきません。
そのため、.on()
jQueryメソッドを使用して、イベントを最も近い静的親に委任する必要があります。
$(function(){
$(".dropdown-menu").on('click', 'li a', function(){
$(".btn:first-child").text($(this).text());
$(".btn:first-child").val($(this).text());
});
});
ここではイベントは静的な親$(".dropdown-menu")
に委任されていますが、イベントは常に利用可能であるため、$(document)
にイベントを委任することもできます。
ブートストラップ3.3.4用に更新:
これにより、要素ごとに異なる表示テキストとデータ値を設定できます。それはまた選択のキャレットを持続させる。
JS:
$(".dropdown-menu li a").click(function(){
$(this).parents(".dropdown").find('.btn').html($(this).text() + ' <span class="caret"></span>');
$(this).parents(".dropdown").find('.btn').val($(this).data('value'));
});
HTML:
<div class="dropdown">
<button class="btn btn-default dropdown-toggle" type="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="true">
Dropdown
<span class="caret"></span>
</button>
<ul class="dropdown-menu" aria-labelledby="dropdownMenu1">
<li><a href="#" data-value="action">Action</a></li>
<li><a href="#" data-value="another action">Another action</a></li>
<li><a href="#" data-value="something else here">Something else here</a></li>
<li><a href="#" data-value="separated link">Separated link</a></li>
</ul>
</div>
私はあなたがブートストラップ3で動作するかなり良いプレゼンテーションで複数のボタンドロップダウンを持っている場合に動作するようにJaiの答えをわずかに改善することができました:
ボタンのコード
<div class="btn-group">
<button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown">
Option: <span class="selection">Option 1</span><span class="caret"></span>
</button>
<ul class="dropdown-menu" role="menu">
<li><a href="#">Option 1</a></li>
<li><a href="#">Option 2</a></li>
<li><a href="#">Option 3</a></li>
</ul>
</div>
JQueryスニペット
$(".dropdown-menu li a").click(function(){
$(this).parents(".btn-group").find('.selection').text($(this).text());
$(this).parents(".btn-group").find('.selection').val($(this).text());
});
私は "selection"クラスに5pxのマージン権も追加しました。
これは、同じページ内の複数のドロップダウンに対して機能します。さらに、選択したアイテムにキャレットを追加しました。
$(".dropdown-menu").on('click', 'li a', function(){
$(this).parent().parent().siblings(".btn:first-child").html($(this).text()+' <span class="caret"></span>');
$(this).parent().parent().siblings(".btn:first-child").val($(this).text());
});
これは私があなたの時間をいくらか節約できることを私が望んでいるこれの私のバージョンです:)
jQueryのパート:
$(".dropdown-menu").on('click', 'li a', function(){
var selText = $(this).children("h4").html();
$(this).parent('li').siblings().removeClass('active');
$('#vl').val($(this).attr('data-value'));
$(this).parents('.btn-group').find('.selection').html(selText);
$(this).parents('li').addClass("active");
});
HTMLパート:
<div class="container">
<div class="btn-group">
<a class="btn btn-default dropdown-toggle btn-blog " data-toggle="dropdown" href="#" id="dropdownMenu1" style="width:200px;"><span class="selection pull-left">Select an option </span>
<span class="pull-right glyphiconglyphicon-chevron-down caret" style="float:right;margin-top:10px;"></span></a>
<ul class="dropdown-menu" role="menu" aria-labelledby="dropdownMenu1">
<li><a href="#" class="" data-value=1><p> HER Can you write extra text or <b>HTLM</b></p> <h4> <span class="glyphicon glyphicon-plane"></span> <span> Your Option 1</span> </h4></a> </li>
<li><a href="#" class="" data-value=2><p> HER Can you write extra text or <i>HTLM</i> or some long long long long long long long long long long text </p><h4> <span class="glyphicon glyphicon-briefcase"></span> <span>Your Option 2</span> </h4></a>
</li>
<li class="divider"></li>
<li><a href="#" class="" data-value=3><p> HER Can you write extra text or <b>HTLM</b> or some </p><h4> <span class="glyphicon glyphicon-heart text-danger"></span> <span>Your Option 3</span> </h4></a>
</li>
</ul>
</div>
<input type="text" id="vl" />
</div>
この単一のjQuery関数はあなたが必要とするすべてをします。
$( document ).ready(function() {
$('.dropdown').each(function (key, dropdown) {
var $dropdown = $(dropdown);
$dropdown.find('.dropdown-menu a').on('click', function () {
$dropdown.find('button').text($(this).text()).append(' <span class="caret"></span>');
});
});
});
あなたは<div class="btn-group open">
でadd class open
を使う必要があります
li
にclass="active"
を追加
$。text()が正確な文字列を返すように@Kyleからの回答に基づいてさらに修正されたので、キャレットをドロップダウンでそのまま残したい場合に備えて、キャレットタグはマークアップとしてではなく文字通りに印刷されます。
$(".dropdown-menu li").click(function(){
$(this).parents(".btn-group").find('.btn').html(
$(this).text()+" <span class=\"caret\"></span>"
);
});
ページ上の複数のドロップダウンのスクリプトを修正しました
$(function(){
$(".dropdown-menu li a").click(function(){
var item = $(this);
var id = item.parent().parent().attr("aria-labelledby");
$("#"+id+":first-child").text($(this).text());
$("#"+id+":first-child").val($(this).text());
});
});
それは長い問題のようです。欲しいのは入力グループにselectタグを実装することだけです。しかし、ブートストラップはそれをしないでしょう: https://github.com/twbs/bootstrap/issues/10486
トリックは単に親のdivに "btn-group"クラスを追加することです
html:
<div class="input-group">
<div class="input-group-btn btn-group">
<button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown">
Product Name <span class="caret"></span>
</button>
<ul class="dropdown-menu" role="menu">
<li><a href="#">A</a></li>
<li><a href="#">B</a></li>
</ul>
</div>
<input type="text" class="form-control">
<span class="input-group-btn">
<button class="btn btn-primary" type="button">Search</button>
</span>
</div>
js:
$(".dropdown-menu li a").click(function(e){
var selText = $(this).text();
$(this).parents('.input-group').find('.dropdown-toggle').html(selText+' <span class="caret"></span>');
});
アイテムをクリックしたら、data-selected-item = 'true'のようなデータ属性を追加して、もう一度取得します。
クリックしたli要素に対して、data-selected-item = 'true'を追加してから、
$('ul.dropdown-menu li[data-selected-item] a').text();
この属性を追加する前に、リスト内の既存のdata-selected-itemを削除するだけです。これがお役に立てば幸いです
JQueryでのデータ属性の使用方法については、 jQueryデータ を参照してください。
複数のドロップダウンを操作するためのもう1つの簡単な方法(ブートストラップ4)
$('.dropdown-item').on('click', function(){
var btnObj = $(this).parent().siblings('button');
$(btnObj).text($(this).text());
$(btnObj).val($(this).text());
});
表示されたJavaScriptを「document.ready」コード内に配置する必要がありました。そうでなければ彼らは働かなかった。多くの人にとってはおそらく明白だが、私にとってはそうではない。あなたがテストしているのであればそのオプションを見てください。
<script type="text/javascript">
$(document).ready(function(){
//rest of the javascript code here
});
</script>
例えば:
HTML:
<div class="dropdown">
<button class="btn btn-default dropdown-toggle" type="button" data-toggle="dropdown">
<BtnCaption>Select item</BtnCaption>
<span class="caret"></span>
</button>
<ul class="dropdown-menu">
<li><a href="#">Option 1</a></li>
<li><a href="#">Option 2</a></li>
<li class="disabled"><a href="#">Option 3</a></li>
</ul>
</div>
私は新しい要素BtnCaptionを使ってボタンのテキストを変更します。
次のテキストを$(document).ready(function () {}
に貼り付けます
JavaScript:
$(".dropdown-menu li:not(.disabled) a").click(function () {
$(this).closest(".dropdown").find(".btn BtnCaption").text($(this).text()));
});
:not(.disabled)
無効なメニュー項目の使用を許可しない