WordPress의 추가 게시물 Ajax 버튼
이 튜토리얼에서는 게시물을 점진적으로 로드하기 위해 WordPress에서 "더 보기" 버튼을 구현하는 문제를 다룹니다. Ajax를 통해. 문제는 jQuery, Ajax 및 WordPress 기능을 통합하여 요청 시 새 게시물을 검색하고 표시하는 것과 관련이 있습니다.
해결책:
index.php 템플릿 파일에서 ID가 "ajax-posts"인 컨테이너 요소를 만들고 제한된 수의 게시물을 쿼리하고 표시하는 PHP 코드를 포함합니다(예: 삼). 추가 게시물 로드를 트리거하려면 ID가 "more_posts"인 버튼을 추가하세요.
functions.php 파일에서 Ajax 요청을 처리하는 함수(more_post_ajax())를 만듭니다. 이 함수는 페이지당 게시물 수와 오프셋을 매개변수로 수신하고 데이터베이스에 쿼리하여 다음 게시물 세트를 검색합니다.
Ajax 호출에서(스크립트 파일 또는 인라인에서) ), Ajax URL을 설정하고 페이지당 게시물 수와 오프셋을 데이터로 전송하고 검색된 게시물을 "ajax-posts" 컨테이너에 추가하고 페이지를 증가시켜 응답을 처리합니다. 번호.
예 코드:
index.php
<div>
functions.php
function more_post_ajax() { // Get offset and number of posts per page $offset = $_POST['offset']; $ppp = $_POST['ppp']; // Query database to retrieve next set of posts // Return retrieved posts echo $posts; exit; }
Ajax 호출
// Set Ajax URL var ajaxUrl = '<?php echo admin_url('admin-ajax.php') ?>'; // When "Load More" button is clicked $('#more_posts').on('click', function() { // Disable button temporarily $(this).attr('disabled', true); // Send Ajax request with offset and number of posts per page $.post(ajaxUrl, { action: 'more_post_ajax', offset: (page * ppp) + 1, ppp: ppp }) .success(function(posts) { // Append retrieved posts to container $('#ajax-posts').append(posts); // Increment page number page++; // Re-enable "Load More" button $('#more_posts').attr('disabled', false); }); });
위 내용은 WordPress 게시물에 \'추가 로드\' Ajax 버튼을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!