Heim >Backend-Entwicklung >PHP-Tutorial >Wie implementiert man einen Ajax-Button „Mehr laden' für WordPress-Beiträge?

Wie implementiert man einen Ajax-Button „Mehr laden' für WordPress-Beiträge?

Patricia Arquette
Patricia ArquetteOriginal
2024-11-29 03:22:12778Durchsuche

How to Implement an

Ajax-Schaltfläche „Mehr Beiträge laden“ in WordPress

Dieses Tutorial befasst sich mit dem Problem der Implementierung einer Schaltfläche „Mehr Beiträge laden“ in WordPress, um Beiträge schrittweise zu laden über Ajax. Das Problem besteht darin, jQuery-, Ajax- und WordPress-Funktionen zu integrieren, um neue Beiträge bei Bedarf abzurufen und anzuzeigen.

Lösung:

In der index.php Vorlagendatei, erstellen Sie ein Containerelement mit der ID „ajax-posts“ und fügen Sie PHP-Code ein, um eine begrenzte Anzahl von Beiträgen (z. B. drei) abzufragen und anzuzeigen. Fügen Sie eine Schaltfläche mit der ID „more_posts“ hinzu, um das Laden zusätzlicher Beiträge auszulösen.

Erstellen Sie in der Datei functions.php eine Funktion (more_post_ajax()), um die Ajax-Anfrage zu verarbeiten. Diese Funktion empfängt den Offset und die Anzahl der Beiträge pro Seite als Parameter und fragt die Datenbank ab, um den nächsten Satz von Beiträgen abzurufen.

Im Ajax-Aufruf (entweder in einer Skriptdatei oder inline ), legen Sie die Ajax-URL fest, senden Sie den Offset und die Anzahl der Beiträge pro Seite als Daten und verarbeiten Sie die Antwort, indem Sie die abgerufenen Beiträge an den Container „ajax-posts“ anhängen und die Seite erhöhen Nummer.

Beispielcode:

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 anrufen

// 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);
    });
});

Das obige ist der detaillierte Inhalt vonWie implementiert man einen Ajax-Button „Mehr laden' für WordPress-Beiträge?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn