


Cara Melaksanakan Ciri AJAX "Load More Posts" dalam WordPress
Artikel ini membincangkan isu pelaksanaan AJAX "Load More Posts " dalam WordPress, yang membolehkan pengguna memuatkan siaran tambahan secara dinamik pada halaman web tanpa perlu memuat semula keseluruhan halaman.
Pernyataan Masalah
Pengguna menghadapi kesukaran semasa cuba melaksanakan ciri ini menggunakan pelbagai kaedah, termasuk yang disebut dalam "Penomboran pada WP_Query Ajax Tersuai" post.
Penyelesaian
Penyelesaian yang disediakan menumpukan pada menambah baik kod untuk memastikan kefungsian yang betul. Aspek utama termasuk:
1. Kod Sisi Pelayan
- Dalam fail templat, pastikan pertanyaan catatan awal mengembalikan bilangan siaran yang diingini setiap halaman.
- Dalam fail fungsi, cipta fungsi untuk mengendalikan permintaan AJAX dan memuatkan lebih banyak siaran secara dinamik. Fungsi ini harus termasuk logik penomboran untuk mendapatkan semula set siaran yang betul.
2. Kod Sebelah Klien (jQuery)
- Di sisi klien, ikat pendengar acara pada butang "Muat Lagi".
- Apabila butang diklik, hantar permintaan AJAX ke fungsi sisi pelayan menggunakan jQuery.
- Lepasi parameter yang diperlukan seperti offset dan bilangan siaran setiap halaman.
- Tambahkan HTML yang dikembalikan pada senarai siaran sedia ada.
3. Pertimbangan Tambahan
- Kendalikan kes tiada lagi siaran untuk dimuatkan dengan melumpuhkan butang "Muat Lagi".
- Untuk mencipta kesan "beban tak terhingga", gunakan tatal tetingkap bukannya acara klik butang.
Kod Pelaksanaan
Ikuti coretan kod yang disediakan untuk melaksanakan penyelesaian:
functions.php:
/** * Handle AJAX "Load More" request */ function load_more_posts() { $offset = $_POST['offset']; $ppp = $_POST['ppp']; $args = [ 'post_type' => 'post', 'posts_per_page' => $ppp, 'offset' => $offset, // Other query parameters... ]; $query = new WP_Query($args); $html = ''; if ($query->have_posts()) { while ($query->have_posts()) { $query->the_post(); $html .= '<div>' . get_the_content() . '</div>'; } wp_reset_postdata(); } else { $html = 'No more posts to load'; } echo $html; exit(); } add_action('wp_ajax_load_more_posts', 'load_more_posts'); add_action('wp_ajax_nopriv_load_more_posts', 'load_more_posts');
script.js:
$(function() { var offset = 0; var ppp = 3; $('#load-more').on('click', function() { $.ajax({ type: 'POST', url: 'path/to/wp-admin/admin-ajax.php', data: { action: 'load_more_posts', offset: offset, ppp: ppp }, success: function(response) { $('#posts').append(response); offset += ppp; } }); // Prevent the button from triggering multiple AJAX requests $('#load-more').attr('disabled', true); }); });
Nota : Gantikan 'path/to/wp-admin/admin-ajax.php' dengan URL sebenar kepada anda Fail admin-ajax.php WordPress.
Kesimpulan
Dengan mengikuti langkah ini, anda boleh melaksanakan ciri AJAX "Muat Lebih Banyak Catatan" untuk tapak WordPress anda, membenarkan pengguna untuk menyemak imbas kandungan yang banyak dengan lancar tanpa perlu memuat semula keseluruhan halaman.
Atas ialah kandungan terperinci Bagaimana untuk Melaksanakan Ciri AJAX \'Muat Lebih Banyak Catatan\' dalam WordPress?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Pembalakan PHP adalah penting untuk memantau dan menyahpepijat aplikasi web, serta menangkap peristiwa kritikal, kesilapan, dan tingkah laku runtime. Ia memberikan pandangan yang berharga dalam prestasi sistem, membantu mengenal pasti isu -isu, dan menyokong penyelesaian masalah yang lebih cepat

Laravel memudahkan mengendalikan data sesi sementara menggunakan kaedah flash intuitifnya. Ini sesuai untuk memaparkan mesej ringkas, makluman, atau pemberitahuan dalam permohonan anda. Data hanya berterusan untuk permintaan seterusnya secara lalai: $ permintaan-

Pelanjutan URL Pelanggan PHP (CURL) adalah alat yang berkuasa untuk pemaju, membolehkan interaksi lancar dengan pelayan jauh dan API rehat. Dengan memanfaatkan libcurl, perpustakaan pemindahan fail multi-protokol yang dihormati, php curl memudahkan execu yang cekap

Laravel menyediakan sintaks simulasi respons HTTP ringkas, memudahkan ujian interaksi HTTP. Pendekatan ini dengan ketara mengurangkan redundansi kod semasa membuat simulasi ujian anda lebih intuitif. Pelaksanaan asas menyediakan pelbagai jenis pintasan jenis tindak balas: Gunakan Illuminate \ Support \ Facades \ http; Http :: palsu ([ 'Google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

Adakah anda ingin memberikan penyelesaian segera, segera kepada masalah yang paling mendesak pelanggan anda? Sembang langsung membolehkan anda mempunyai perbualan masa nyata dengan pelanggan dan menyelesaikan masalah mereka dengan serta-merta. Ia membolehkan anda memberikan perkhidmatan yang lebih pantas kepada adat anda

Alipay Php ...

Artikel membincangkan pengikatan statik lewat (LSB) dalam PHP, yang diperkenalkan dalam Php 5.3, yang membolehkan resolusi runtime kaedah statik memerlukan lebih banyak warisan yang fleksibel. Isu: LSB vs polimorfisme tradisional; Aplikasi Praktikal LSB dan Potensi Perfo

Artikel ini membincangkan menambah fungsi khusus kepada kerangka kerja, memberi tumpuan kepada pemahaman seni bina, mengenal pasti titik lanjutan, dan amalan terbaik untuk integrasi dan debugging.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),