在Bootstrap中集成Mmenu

时间:2013-06-03 08:44:49

标签: jquery twitter-bootstrap

我想在Bootstrap中集成 Jquery Mmenu ,自动让bootstrap通过响应式设计切换到这个滑动的左侧菜单,而不是显示本机顶部垂直响应式菜单。

任何想法或方法?

Jquery Mmenu:http://mmenu.frebsite.nl

我提前感谢你们。

5 个答案:

答案 0 :(得分:5)

好吧,几个小时前我开始了同样的任务,我希望能在这里找到答案来帮助我。

我现在已经开始工作,我将分享我所学到的知识,尽管我是新手。如果你看到菜鸟的错误,别人可以随意插话。猜猜是时候回报社区了,因为我的许多问题已在这里得到解答。

这里是:

看看这个jsFiddle,看看我的完整示例代码和演示:http://jsfiddle.net/acterry/fMYpg/

您可以使用垂直分隔线来查看导航从一种样式更改为另一种样式。

我想使用相同的nav ul驱动两个菜单。但在浏览了Jquery.mmenu的源代码之后,我看到以下我知道会引起问题的事情:

  • mmenu围绕HTML
  • 包装新容器(默认情况下为div)
  • mmenu以可能导致bootstrap navbar
  • 的方式修改菜单ul
  • mmenu没有破坏自身的功能并撤消它导致的DOM更改

作为概念验证,我使用bootstraps预定义的响应断点来确定显示哪种导航样式。

这是菜单部分的HTML

<div class="navbar navbar-inverse navbar-fixed-top">
  <div class="visible-desktop navbar-inner">
    <div class="container">
      <!-- .btn-navbar is used as the toggle for collapsed navbar content -->  
      <a class="btn btn-navbar" data-toggle="collapse" data-target=".nav-collapse">
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
      </a>
      <a class="brand" href="/">My Site</a>
      <!-- Everything you want hidden at 940px or less, place within here -->
      <div class="nav-collapse collapse">
        <ul class="nav" id="mainSiteMenu">
          <li><a href="#">Home</a>
          </li>
          <li><a href="#">Link 1</a>
          </li>
          <li><a href="#">Link 2</a>
          </li>
          <li><a href="#">Link 3</a>
          </li>
        </ul>
      </div>
    </div>
  </div>
  <div class="hidden-desktop navbar-inner">
    <div class="container">
      <!-- .btn-navbar is used as the toggle for collapsed navbar content -->
      <a class="btn btn-navbar" href="#mainSiteMenuMMenuNav">
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
      </a>
      <a class="brand" href="/">My Site</a>
    </div>
  </div>
</div>
<nav id="mainSiteMenuMMenuNav"></nav>

以下是步骤的快速细分:

  1. (上面未显示)如果页面中的所有HTML都不在单个容器中,请将其包装在div中。如果你使用的不是div,那么在mmenu配置中适当地设置pageNodetype
  2. 定义您的nav ul,如引导程序组件页面上所示。但是,给UL一个ID,以便我们以后可以参考。
  3. 复制navbar-inner div
  4. 在第一个导航栏内部,将visible-desktop添加到div的class参数 - 这是将向桌面用户显示的导航栏。 Bootstrap会将其隐藏在桌面/平板电脑宽度断点之下
  5. 在第二个navbar-inner中,将hidden-desktop添加到div的class参数中 - 这是将显示给平板电脑/手机的导航栏(或默认情况下浏览器宽度小于940px的任何其他内容)
  6. 在导航栏的结束div后添加一个带有ID的空导航容器(我使用了mainSiteMenuNav)。这就是mmenu的UL。
  7. 在我的代码中,注意第二个navbar-inner中的btn-navbar链接。这是打开/关闭mmenu的按钮。 href锚需要匹配您为空导航容器提供的任何ID
  8. 由于我无法在两个菜单中使用完全相同的UL,因此我决定使用jQuery以编程方式复制页面加载时引导程序导航栏使用的那个,并将其填充到空导航容器中以供mmenu使用。

    以编程方式创建空导航容器可能更简洁。我明天可能会这样做。

    此javascript复制UL,将其放入导航容器并使用复制的UL实例化mmenu:

    $(function () {
        $("#mainSiteMenuMMenuNav").append($("#mainSiteMenu").clone().attr("id", "mainSiteMenuMMenu").attr("class", ""));
        $("#mainSiteMenuMMenuNav").mmenu({
            configuration: {
                pageNodetype: "div"
            }
        });
    });
    

    应该这样做。如果您遇到问题,请仔细检查一切。再说一次,我刚刚在几个小时前就想到了......所以它可能不是一个万无一失的解决方案。

    如果有人有更好的方法或看到问题,请告诉我。

答案 1 :(得分:1)

希望这是主题和有用的。我使用了正常的bootstrap菜单,直到min-width:1060px,然后是MMenu从那时起。这是JS(我使用enquire.js来匹配媒体查询)。

// uses enquire.js to fire js on media queries
// https://github.com/WickyNilliams/enquire.js/
enquire.register("screen and (max-width:1060px)", {

// Wait until media query is matched
deferSetup: true,
// Fires once 
setup: function() {
// requires an empty <nav id="menu"></nav>
$('.navbar-nav').clone().appendTo('#menu');
$('#menu > ul').attr("id", "mmenu");
//clean up mmenu by removing bootstrap classes
$('#mmenu ul').removeClass('dropdown-menu animated fadeInDown');
$('#mmenu li').removeClass('dropdown');
$('#mmenu li a').removeClass('dropdown-toggle').removeAttr("data-toggle data-target");
// $('#mmenu li a').removeAttr("data-toggle data-target");
$('#mmenu').removeClass('nav navbar-nav');

},

// If supplied, triggered when a media query matches.
match: function() {

//Show mmenu on media query match
$("#menu").mmenu({
"offCanvas": {
"position": "right"
}
});
},

// *from a matched state to an unmatched state*.
unmatch: function() {
//Hide mmenu
$('#menu').trigger('close.mm');
// $('#mmenu').remove();

}

});

答案 2 :(得分:0)

我添加了一个额外的示例,在向下滚动时强制引导导航栏停留在窗口顶部。

http://jsfiddle.net/acterry/yC7R3/

我将pageNodetype更改为“section”以更改mmenu进行修改的位置。

还添加了这个CSS

/* Push down the sidebar menu so that first item is not covered up by sticky navbar */
#mainSiteMenuMMenuNav.mmenu-opened {
    top: 50px;
}

/* force the top navbar to stick to top of window when you scroll down*/
@media (max-width: 979px) {
    /* Enable use of floated navbar text */
    .navbar-text.pull-right {
        float: none;
        padding-left: 5px;
        padding-right: 5px;
    }
    .navbar-fixed-top, .navbar-fixed-bottom {
        position: fixed;
        margin-left: 0px;
        margin-right: 0px;
    }
}

答案 3 :(得分:0)

由于任何遇到相同问题且正在寻找有效工作的人仍然可以开放:Check this out

我刚刚在我的项目中使用过它并不容易......

答案 4 :(得分:0)

如果您使用的是Blogger平台,则可以使用我在https://shareusyourday.blogspot.com/2020/09/mmenu-bootstrap-wrapper.html中找到的方法

您需要具备4个主要部分

  1. 包含标签的内容。 -创建画布菜单。
  2. Mmenu CDN文件-, 链接href ='https://cdnjs.cloudflare.com/ajax/libs/jQuery.mmenu/8.5.14/mmenu.min.css'rel ='stylesheet'/>
  3. 菜单Javascript
  4. 引导菜单HTML标记 (您可以在帖子中找到上面的示例)

Adios