flo*_*oop 6 html javascript jquery twitter-bootstrap
我有一个下拉按钮,其中包含固定到页面不同部分的内容列表.此下拉列表仅适用于移动设备.
但问题是,点击它后,下拉列表不会关闭.无论如何我可以点击它关闭?我试过环顾四周,但它不适用于我的.
<div id="mobile-dropdown" class="nav2 w" data-spy="affix" data-offset-top="350">
<div class="container">
<div class="pull-left" style="margin-top:3px; margin-right:3px;">Jump to </div>
<div class="pull-left">
<div class="btn-group mob-fl">
<button type="button" class="btn btn-default btn-sm dropdown-toggle" data-toggle="dropdown" aria-expanded="false">
Categories
<span class="caret"></span>
</button>
<ul class="dropdown-menu" role="menu">
<li><a href="#1">One</a></li>
<li><a href="#2">Two</a></li>
<li><a href="#3">Three</a></li>
<li><a href="#4">Four</a></li>
</ul>
</div>
</div>
</div>
</div>
Run Code Online (Sandbox Code Playgroud)
我还看了一下bootstrap的js本身并抓住了这一行:
if ('ontouchstart' in document.documentElement && !$parent.closest('.navbar-nav').length) {
// if mobile we use a backdrop because click events don't delegate
$('<div class="dropdown-backdrop"/>').insertAfter($(this)).on('click', clearMenus)
}
Run Code Online (Sandbox Code Playgroud)
这是它不会关闭的原因吗?是否有任何解决方法使其工作?
编辑:
所以在一些帮助下我得到了这个脚本:
$('document').ready(function() {
$("a.dropdown-toggle").click(function(ev) {
$("a.dropdown-toggle").dropdown("toggle");
return false;
});
$("ul.dropdown-menu a").click(function(ev) {
$("a.dropdown-toggle").dropdown("toggle");
return false;
});
});
Run Code Online (Sandbox Code Playgroud)
我的javascript非常弱,我如何编辑它以使其仅在我的"mobile-dropdown"id div中工作.
好了到目前为止我已将我的脚本更新为:
$('document').ready(function() {
$("#subject_cat_mob .dropdown-toggle").click(function(ev) {
$("#subject_cat_mob .dropdown-toggle").dropdown("toggle");
return false;
});
$("#subject_cat_mob ul.dropdown-menu a").click(function(ev) {
$("#subject_cat_mob .dropdown-toggle").dropdown("toggle");
return false;
});
});
Run Code Online (Sandbox Code Playgroud)
它的工作原理就像我想要的那样.但是第一次之后下拉列表将不会再次打开.
这应该使它适用于您的 HTML:
$('document').ready(function() {
$("#mobile-dropdown .dropdown-toggle").click(function() {
$(this).dropdown("toggle");
return false;
});
});
Run Code Online (Sandbox Code Playgroud)
更新
这是一个包含平滑滚动功能的工作示例:
$(function() {
$('a[href*=#]:not([href=#])[href^="#"]:not([data-toggle])').click(function() {
$(this).dropdown("toggle"); // this is the important part!
if (location.pathname.replace(/^\//,'') == this.pathname.replace(/^\//,'') && location.hostname == this.hostname) {
var target = $(this.hash);
target = target.length ? target : $('[name=' + this.hash.slice(1) +']');
if (target.length) {
$('html,body').animate({
scrollTop: target.offset().top-100
}, 1000);
return false;
}
}
});
});
Run Code Online (Sandbox Code Playgroud)
注意到第三行了吗?这就是它所需要的:$(this).dropdown("toggle");.
您可以查看JSFiddle 上的工作示例。
| 归档时间: |
|
| 查看次数: |
17425 次 |
| 最近记录: |