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

WBOY
풀어 주다: 2023-10-24 11:00:18
원래의
1271명이 탐색했습니다.

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

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

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

먼저, 뉴스 목록을 표시하려면 기본 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的服务器端接口文件,用于模拟后端数据。以下是一个简单的示例:

新闻标题 ' . ($start + $i) . ''; } 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!