我的测试页 https://osticketawesome.com/support/awesome/inc/test.html
我试图将汉堡菜单与Sidr jQuery插件结合起来创建侧边菜单。
它在Chrome,FF,IE和Edge中完美运行,但在移动浏览器我已经过测试(Android / Chrome和iPhone / Safari)菜单切换但是按钮如果我点按按钮的外边缘,则仅动画。
<div id="header">
<div id="right-menu" href="#right-menu">
<button href="#right-menu" class="c-hamburger c-hamburger--htx">
<span>toggle menu</span>
</button>
</div>
</div>
$(document).ready(function() {
var toggles = document.querySelectorAll(".c-hamburger");
for (var i = toggles.length - 1; i >= 0; i--) {
var toggle = toggles[i];
toggleHandler(toggle);
};
function toggleHandler(toggle) {
toggle.addEventListener( "click", function(e) {
e.preventDefault();
(this.classList.contains("is-active") === true) ?
this.classList.remove("is-active") :
this.classList.add("is-active");
});
}
$('.c-hamburger').sidr({
name: 'right_menu',
side: 'right',
body: 'container'
});
})();
有什么想法吗?
答案 0 :(得分:1)
我刚刚解决了这个问题。如果它以后帮助任何人,我只是加倍了以下功能:
function toggleHandler(toggle) {
toggle.addEventListener( "click", function(e) {
e.preventDefault();
(this.classList.contains("is-active") === true) ? this.classList.remove("is-active") : this.classList.add("is-active");
});
toggle.addEventListener( "touchstart", function(e) {
e.preventDefault();
(this.classList.contains("is-active") === true) ? this.classList.remove("is-active") : this.classList.add("is-active");
});
}