jQuery媒体查询切换按钮 - 根据屏幕宽度的不同操作

时间:2018-02-19 23:58:25

标签: javascript jquery html mmenu matchmedia

我有一个切换按钮,它基本上显示/隐藏产品索引页面上的过滤器列表。桌面很简单,单击按钮时,将使用以下脚本显示或隐藏面板:

$(".filter-toggle").click(function(){
    $(".grid").toggleClass("hide-filters");
});

当浏览器低于1024px时,我使用mmenu插件复制过滤器内容并将其移动到离开画布面板。代码如下:

$(document).ready(function() {
    $(".filters").mmenu({
        // Options
        navbar: {
            title: "Filters"
        }
    }, {
        // Configuration
        clone: true,
        offCanvas: {
            pageSelector: ".page"
        },
        classNames: {
            selected: "active"
        }
    });

    var API = $(".filters").data("mmenu");
    var $icon = $(".filter-toggle");

    $icon.on("click", function() {
        API.open();
    });
});

显然(在分钟)单击切换按钮时,它将显示/隐藏页面上的内容,但同时也会触发滑出菜单。

我的问题是如何在需要时才运行相关脚本。是否也可以在调整大小而不仅仅是在pageLoad / refresh上执行此操作?

我尝试使用matchMedia。这是一个快速的CodePen,显示我在哪里......

this alternative

看起来它起作用了。在1024px以上,切换工作。缩小浏览器意味着按钮触发了滑出式面板 - 太棒了!但是,当缩放到桌面时,只要单击切换,就会触发滑出菜单。在刷新时它再次起作用......直到你缩小浏览器并再次备份。

有什么想法吗?

1 个答案:

答案 0 :(得分:1)

您可以侦听窗口调整大小事件,并相应地触发功能。例如,在jQuery中:

$(window).on('resize', function(e) {
  var windowWidth = $(window).width();

  if (windowWidth < 1024) {
    // initialize small viewport functionality
  } else {
    // initialized large viewport functionality
  }
});

但是,在切换回桌面时,您需要一种方法来禁用该mmenu插件,并将其包含在您在该条件下运行的任何脚本中。

或者,the mmenu "Responsive Layout" documentation提供了使用CSS媒体查询在某些断点处隐藏克隆菜单的示例。