>웹 프론트엔드 >JS 튜토리얼 >HTML, CSS 및 jQuery를 사용하여 무한 스크롤 뉴스 목록을 만드는 방법

HTML, CSS 및 jQuery를 사용하여 무한 스크롤 뉴스 목록을 만드는 방법

WBOY
WBOY원래의
2023-10-24 11:00:181477검색

HTML, CSS 및 jQuery를 사용하여 무한 스크롤 뉴스 목록을 만드는 방법

HTML, CSS 및 jQuery를 사용하여 무한 스크롤 뉴스 목록을 만드는 방법

웹 개발에서 무한 스크롤은 일반적인 상호 작용 기술이며, 특히 대량의 데이터를 로드해야 하는 뉴스 목록과 같은 페이지에 적합합니다. 이 기사에서는 HTML, CSS 및 jQuery를 사용하여 무한 스크롤 뉴스 목록을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.

먼저, 뉴스 목록을 표시하려면 기본 HTML 구조가 필요합니다. 간단한 예는 다음과 같습니다.

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <title>无限滚动新闻列表</title>
  <link rel="stylesheet" href="style.css">
</head>
<body>
  <div id="news-list">
    <ul>
      <!-- 这里将显示动态加载的新闻 -->
    </ul>
    <div id="loading-indicator">正在加载更多...</div>
  </div>

  <script src="jquery.js"></script>
  <script src="script.js"></script>
</body>
</html>

다음으로 이 뉴스 목록에 대한 몇 가지 기본 CSS 스타일을 설정해야 합니다. style.css라는 파일을 만들고 다음 코드를 추가합니다. style.css 的文件,并添加以下代码:

#news-list {
  overflow-y: scroll;
  height: 400px;
}
ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
li {
  padding: 10px;
  border-bottom: 1px solid #ccc;
}
#loading-indicator {
  text-align: center;
  padding: 10px;
  color: #999;
}

在这个示例中,我们设置了新闻列表容器 #news-list 的高度为 400px,并使用 overflow-y: scroll; 属性来实现垂直滚动。新闻列表的样式使用了无序列表 ul 和列表项 li,并为列表项添加了一条灰色的底边线。加载更多提示信息的样式在 #loading-indicator 中设置。

好了,现在我们来撰写 JavaScript 代码,使用 jQuery 实现无限滚动效果。创建一个名为 script.js 的文件,并添加以下代码:

$(document).ready(function() {
  var page = 1;
  var loading = false;

  function loadData() {
    if (loading) return;

    loading = true;
    $('#loading-indicator').show();

    // 发起异步请求加载数据
    $.ajax({
      url: 'news.php', // 替换为加载数据的API地址
      type: 'GET',
      data: { page: page },
      success: function(data) {
        // 数据加载成功后的处理
        if (data.length > 0) {
          $('#news-list ul').append(data);
          page++;
        }

        loading = false;
        $('#loading-indicator').hide();
      }
    });
  }

  // 初始化加载第一页的数据
  loadData();

  // 当滚动到底部时触发加载下一页数据
  $('#news-list').scroll(function() {
    var distance = $('#news-list ul').outerHeight() - $('#news-list').scrollTop() - $('#news-list').height();
    if (distance < 50) {
      loadData();
    }
  });
});

在这段代码中,我们首先定义了一个变量 page 表示当前加载的页数,以及一个变量 loading 表示是否正在加载数据。loadData 函数中,我们判断当前是否有数据正在加载,如果有则直接返回,否则显示加载提示信息,并且发送异步请求获取新闻数据。在请求成功后,将新闻数据追加到新闻列表中,并更新页数。最后,隐藏加载提示信息并将 loading 标记设置为 false

完成以上代码后,我们需要创建一个名为 news.php 的服务器端接口文件,用于模拟后端数据。以下是一个简单的示例:

<?php
$page = $_GET['page'];
$pageSize = 10;
$start = ($page - 1) * $pageSize;

$data = [];

// 模拟加载数据
for ($i = 1; $i <= $pageSize; $i++) {
  $data[] = '<li>新闻标题 ' . ($start + $i) . '</li>';
}

echo implode('', $data);

在这个示例中,我们使用 $page 来获取当前请求的页数,并使用 $pageSize 设置每页显示的新闻数量。然后,通过一个简单的循环来生成模拟的新闻数据,并返回给前端。

最后,将下载好的 jQuery 文件 jquery.js 和页面所需的样式文件 style.css、脚本文件 script.js 和服务器端接口文件 news.phprrreee

이 예에서는 뉴스 목록 컨테이너 #news-list의 높이를 400px로 설정했습니다. 수직 스크롤을 구현하려면 overflow-y: scroll; 속성을 ​​사용하세요. 뉴스 목록의 스타일은 순서가 지정되지 않은 목록 ul과 목록 항목 li를 사용하고 목록 항목에 회색 하단 줄을 추가합니다. 추가 프롬프트 정보를 로드하는 스타일은 #loading-indicator에서 설정됩니다.

좋아, 이제 JavaScript 코드를 작성하고 jQuery를 사용하여 무한 스크롤 효과를 구현해 보겠습니다. script.js라는 파일을 만들고 다음 코드를 추가합니다: 🎜rrreee🎜이 코드에서는 먼저 현재 로드된 페이지 번호를 나타내는 변수 page를 정의하고 데이터가 로드되고 있는지 여부를 나타내는 변수 loading. loadData 함수에서는 현재 로드 중인 데이터가 있는지 확인하고, 있으면 직접 반환합니다. 그렇지 않으면 로드 프롬프트 정보가 표시되고 뉴스 데이터를 얻기 위해 비동기 요청이 전송됩니다. 요청이 성공하면 뉴스 데이터가 뉴스 목록에 추가되고 페이지 번호가 업데이트됩니다. 마지막으로 로딩 프롬프트를 숨기고 loading 태그를 false로 설정하세요. 🎜🎜위 코드를 완성한 후 백엔드 데이터를 시뮬레이션하려면 news.php라는 서버측 인터페이스 파일을 생성해야 합니다. 다음은 간단한 예입니다. 🎜rrreee🎜이 예에서는 $page를 사용하여 현재 요청된 페이지 수를 가져오고 $pageSize를 사용하여 표시되는 크기를 설정합니다. 각 페이지의 뉴스 수. 그런 다음 간단한 루프를 통해 시뮬레이션된 뉴스 데이터가 생성되어 프런트 엔드로 반환됩니다. 🎜🎜마지막으로 페이지 플레이스에 필요한 jQuery 파일 jquery.js와 스타일 파일 style.css, 스크립트 파일 script.js를 다운로드합니다. 서버측 인터페이스 파일 news.php와 동일한 디렉토리에 있습니다. 🎜🎜위는 HTML, CSS 및 jQuery를 사용하여 무한 스크롤 뉴스 목록을 만드는 기본 단계 및 코드 예제입니다. 실제 필요에 따라 스타일을 조정하고 서버측 인터페이스 파일을 수정하여 실제 뉴스 데이터를 로드할 수 있습니다. 이 글이 여러분에게 도움이 되기를 바라며, 우아한 무한 스크롤 뉴스 목록을 구현해 보시길 바랍니다! 🎜

위 내용은 HTML, CSS 및 jQuery를 사용하여 무한 스크롤 뉴스 목록을 만드는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.