基于Bootstrap實現(xiàn)的下拉菜單手機端不能選擇菜單項的原因附解決辦法
基于Bootstrap做的下拉菜單在電腦瀏覽器中可正常使用,在手機瀏覽器中能彈出下拉列表,卻不能選擇列表中的菜單項,通過自己百度查找原因?qū)ootstrap腳本文件中的ontouchstart 替換為 disable-ontouchstart可以解決,替換后并不能解決。(紅米手機UC瀏覽器不支持,小米手機UC瀏覽器正常,其他暫時未測試)
jquery:v1.11.2
bootstrap:v3.3.4
以下為前臺頁面代碼:
<div class="input-group"> <span class="input-group-addon" id="sizing-addon2">本外地福利:</span> <div class="btn-group"> <button type="button" class="btn btn-default dropdown-toggle" id="btnFuLi" name="btnFuLi" data-toggle="dropdown" value="" aria-expanded="false"> 請選擇本外地福利… <span class="caret"></span> </button> <ul class="dropdown-menu" id="UiFuLi" role="menu"> <li><a title='1' href='#'>本地福利</a></li><li class='divider'></li> <li><a title='2' href='#'>外地福利</a></li><li class='divider'></li> </ul> <input id="txtFuLi" name="本外地福利"/> </div> </div>
以下為JS腳本:(給下拉菜單項添加click)
DataBindFuLi: function () { $("#UiFuLi li a").bind("click", function () { var $this = $(this); var $a = $this.parent().parent().prev() var t = $this.text(); $a.val($this.attr('title')); $('#txtFuLi').val($this.attr('title')); $a.text($this.text()); $a.append("<span class='caret'>"); }); }
解決方法如下所示:
以下代碼手機瀏覽器不支持,將以下元素指定ID賦值即可解決()
$this.parent().parent().prev()
調(diào)整后代碼:
$("#drpWorkType li a").bind("click", function () { var $this = $(this); //var $a = $this.parent().parent().prev() $('#txtWorkType').val($this.attr('title')); $('#btnWorkType').val($this.attr('title')); $('#btnWorkType').text($this.text()); //$a.val($this.attr('title')); //$a.text($this.text()); //$a.append("<span class='caret'>"); });
以上所述是小編給大家介紹的基于Bootstrap實現(xiàn)的下拉菜單手機端不能選擇菜單項的原因附解決辦法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
js中判斷Object、Array、Function等引用類型對象是否相等
項目中有時會需要對引用類型進行比較,如常見的object和array,我們知道,引用類型無法直接使用 == 或=== 取得期待結(jié)果,因此需要一個迭代的compare函數(shù)轉(zhuǎn)化成原始類型進行比較2012-08-08