>백엔드 개발 >PHP 튜토리얼 >WordPress 게시물에 \'추가 로드\' Ajax 버튼을 구현하는 방법은 무엇입니까?

WordPress 게시물에 \'추가 로드\' Ajax 버튼을 구현하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-29 03:22:12778검색

How to Implement an

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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