jQuery 上下滑动菜单是一种使用 jQuery 库实现的交互式菜单,用户可以通过鼠标滚轮或触摸板滑动来展开和收起菜单项。这种菜单通常用于移动设备或触摸屏设备,以提供更好的用户体验。
以下是一个简单的 jQuery 垂直滑动菜单的实现示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>jQuery 滑动菜单</title>
<style>
#menu {
width: 200px;
border: 1px solid #ccc;
}
.menu-item {
overflow: hidden;
transition: height 0.3s ease;
}
.menu-item > div {
padding: 10px;
background-color: #f9f9f9;
}
</style>
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
</head>
<body>
<div id="menu">
<div class="menu-item">
<div>菜单项 1</div>
<div>子菜单项 1.1</div>
<div>子菜单项 1.2</div>
</div>
<div class="menu-item">
<div>菜单项 2</div>
<div>子菜单项 2.1</div>
<div>子菜单项 2.2</div>
</div>
</div>
<script>
$(document).ready(function() {
$('#menu .menu-item').on('mouseenter', function() {
var $this = $(this);
$this.css('height', $this.find('div').length * 40 + 'px');
}).on('mouseleave', function() {
$(this).css('height', '40px');
});
});
</script>
</body>
</html>
原因:可能是由于设备不支持触摸事件或 jQuery 版本不兼容。
解决方法:
$(document).ready(function() {
$('#menu .menu-item').on('mouseenter', function() {
var $this = $(this);
$this.css('height', $this.find('div').length * 40 + 'px');
}).on('mouseleave', function() {
$(this).css('height', '40px');
}).on('wheel', function(e) {
if (e.originalEvent.deltaY > 0) {
$(this).css('height', Math.max(40, $(this).height() - 40) + 'px');
} else {
$(this).css('height', Math.min($(this).find('div').length * 40, $(this).height() + 40) + 'px');
}
});
});
通过以上方法,可以确保滑动菜单在不同设备上的兼容性和响应性。
领取专属 10元无门槛券
手把手带您无忧上云