我有一个切换按钮,它基本上显示/隐藏产品索引页面上的过滤器列表。桌面很简单,单击按钮时,将使用以下脚本显示或隐藏面板:
$(".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,显示我在哪里......
看起来它起作用了。在1024px以上,切换工作。缩小浏览器意味着按钮触发了滑出式面板 - 太棒了!但是,当缩放到桌面时,只要单击切换,就会触发滑出菜单。在刷新时它再次起作用......直到你缩小浏览器并再次备份。
有什么想法吗?
答案 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媒体查询在某些断点处隐藏克隆菜单的示例。