基于Bootstrap实现的下拉菜单手机端不能选择菜单项的原因附解决办法
基于Bootstrap做的下拉菜单在电脑浏览器中可正常使用,在手机浏览器中能弹出下拉列表,却不能选择列表中的菜单项,通过自己百度查找原因将bootstrap脚本文件中的ontouchstart替换为disable-ontouchstart可以解决,替换后并不能解决。(红米手机UC浏览器不支持,小米手机UC浏览器正常,其他暂时未测试)
jquery:v1.11.2
bootstrap:v3.3.4
以下为前台页面代码:
<divclass="input-group"> <spanclass="input-group-addon"id="sizing-addon2">本外地福利:</span> <divclass="btn-group"> <buttontype="button"class="btnbtn-defaultdropdown-toggle"id="btnFuLi"name="btnFuLi"data-toggle="dropdown" value=""aria-expanded="false"> 请选择本外地福利…<spanclass="caret"></span> </button> <ulclass="dropdown-menu"id="UiFuLi"role="menu"> <li><atitle='1'href='#'>本地福利</a></li><liclass='divider'></li> <li><atitle='2'href='#'>外地福利</a></li><liclass='divider'></li> </ul> <inputid="txtFuLi"name="本外地福利"/> </div> </div>
以下为JS脚本:(给下拉菜单项添加click)
DataBindFuLi:function(){ $("#UiFuLilia").bind("click",function(){ var$this=$(this); var$a=$this.parent().parent().prev() vart=$this.text(); $a.val($this.attr('title')); $('#txtFuLi').val($this.attr('title')); $a.text($this.text()); $a.append("<spanclass='caret'>"); }); }
解决方法如下所示:
以下代码手机浏览器不支持,将以下元素指定ID赋值即可解决()
$this.parent().parent().prev()
调整后代码:
$("#drpWorkTypelia").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("<spanclass='caret'>"); });
以上所述是小编给大家介绍的基于Bootstrap实现的下拉菜单手机端不能选择菜单项的原因附解决办法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!