jQuery 是一个快速、小巧且功能丰富的 JavaScript 库,它简化了 HTML 文档遍历、事件处理、动画和 Ajax 交互。自动加载更多(通常称为“无限滚动”或“滚动分页”)是一种网页设计技术,当用户滚动到页面底部时,会自动加载更多内容。
以下是一个简单的 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>
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<style>
.item {
height: 200px;
border: 1px solid #ccc;
margin: 10px;
padding: 10px;
}
.loading {
text-align: center;
padding: 10px;
}
</style>
</head>
<body>
<div id="content">
<!-- 初始内容 -->
<div class="item">Item 1</div>
<div class="item">Item 2</div>
<div class="item">Item 3</div>
</div>
<div class="loading">加载中...</div>
<script>
$(document).ready(function() {
var loading = false;
$(window).scroll(function() {
if ($(window).scrollTop() + $(window).height() >= $(document).height() - 100) {
if (!loading) {
loading = true;
$('.loading').show();
// 模拟加载更多内容
setTimeout(function() {
for (var i = 4; i <= 10; i++) {
$('#content').append('<div class="item">Item ' + i + '</div>');
}
loading = false;
$('.loading').hide();
}, 1000);
}
}
});
});
</script>
</body>
</html>
setTimeout
或 debounce
函数来限制滚动事件的触发频率。通过以上方法,可以有效解决 jQuery 自动加载更多时遇到的一些常见问题。