AJAX jQuery · Memuat Beberapa Bagian Halaman Sekaligus dalam Satu Kali Permintaan
Ini adalah metode dasar yang sering Anda gunakan untuk memuat sebagian halaman ke dalam kontainer yang sudah dipersiapkan menggunakan AJAX. Di sini Saya menggambarkan Anda akan memuat elemen #content
dari halaman /p/sample-page.html ke dalam elemen #container
:
$('button').on("click", function() {
$('#container').load('/p/sample-page.html #content');
});
Setelah tombol diklik, maka elemen #content
dari halaman /p/sample-page.html akan termuat di dalam elemen #container
. Ini adalah kasus yang sederhana. Namun kasus ini akan menjadi lebih rumit ketika Anda ingin memuat beberapa bagian dari halaman lain secara bersamaan dalam satu kali permintaan. Sebagai contoh, Anda ingin memuat bagian posting, navigasi halaman dan komentar secara bersamaan dalam satu kali permintaan HTTP ke dalam beberapa kontainer yang sudah dipersiapkan. Berikut ini adalah cara yang tidak efisien:
$('button').on("click", function() {
$('#container-1').load('http://blog.my_site.com/p/sample-page.html .post');
$('#container-2').load('http://blog.my_site.com/p/sample-page.html #nav');
$('#container-3').load('http://blog.my_site.com/p/sample-page.html #comments');
});
Lebih Efisien: Gunakan $.get()
Jangan memakai jQuery .load()
untuk memuat beberapa bagian halaman sekaligus. Tapi gunakan jQuery $.get()
:
$('button').on("click", function() {
$.get('http://blog.my_site.com/p/sample-page.html', function(data) {
$('#container-1').html($(data).find('.post'));
$('#container-2').html($(data).find('#nav'));
$('#container-3').html($(data).find('#comments'));
});
});
Pada metode ini, Anda mengeklik sebuah tombol. Kemudian permintaan akan terjadi. Setelah proses permintaan berhasil dilakukan dan halaman yang diminta berhasil dipanggil, maka halaman tersebut tidak akan langsung dimuat ke dalam area/kontainer yang sudah dipersiapkan, melainkan masih berada di dalam parameter data
.
Pada kasus ini, parameter data
bisa disamakan sebagai keseluruhan HTML dari halaman http://blog.my_site.com/p/sample-page.html.
Dari parameter tersebut Anda bisa menelusuri bagian-bagian halaman lainnya dengan cara menyeleksi elemen yang diinginkan di dalam $(data)
untuk kemudian bisa dimuat ke dalam kontainer yang diinginkan melalui jQuery manipulasi DOM seperti .html()
, .text()
, .append()
dan .prepend()
atau yang lainnya.
Demo?
Jika Anda sedang menggunakan peramban Firefox, klik pada menu drop-down di pojok kiri atas. Pilih menu Web Developer kemudian klik sub menu Scratchpad (Atau cukup tekan tombol Shift+F4). Salin kode di bawah ini kemudian tempelkan di dalam editor Scratchpad:
$('a').click(function() {
$.get(this.href, function(data) {
$('.post').html($(data).find('.post').html());
$('#blog-pager').html($(data).find('#blog-pager').html());
$('#comments').html($(data).find('#comments').html());
}, 'html');
return false;
});
Klik menu Execute dan pilih Run:
Sekarang klik salah satu tautan pada daftar entri/posting populer di sidebar blog ini dan tunggu beberapa saat sampai bagian dari halaman tersebut termuat. Jika berhasil, maka bagian yang akan berganti isinya adalah ada pada posting, navigasi halaman blog dan isi komentar (isi posting akan berubah, tautan navigasi halaman akan berubah dan isi komentar juga akan berubah).
Catatan dan Tambahan
jQuery .load()
bisa menerima beberapa selektor sekaligus, jika Anda tidak tahu:
// Memuat `#sidebar`, `#comments` dan `#blog-pager`
// dari `http://abc_site.com/sample-page.html` ke dalam `#container`
$('#container').load('http://abc_site.com/sample-page.html #comments,#sidebar,#blog-pager');
Jika proses pemuatan menggunakan $.get()
gagal (yang Saya alami adalah muncul pesan error TypeError: n.innerHTML is undefined
), cobalah untuk menggunakan pola ini:
$.get('http://abc_site.com/sample-page.html', {}, function(data) {
// Lakukan sesuatu dengan `$(data)`
}, 'html');
Labels: JavaScript, jQuery, Lanjutan, Masalah
17 Comments:
Ada masalah lain gak sih dalam hal ini selain masalah pemuatan gagal..?
By Sinto, at Monday, February 25, 2013 at 1:02:00 PM GMT+7
Masalah umum:
1. Tombol Back dan Forward
2. Inline JavaScript
1. Contoh yang Saya jelaskan/tuliskan di atas cuma menunjukkan tentang cara memuat halaman lain ke dalam halaman yang sedang aktif tanpa melakukan proses pemuatan halaman baru. Tapi masalahnya, saat bagian halaman sudah termuat, kita tidak bisa kembali lagi ke tepat awal meski dengan menekan tombol Back atau Forward. Solusinya bisa memakai plugin JQuery BBQ. Tapi untuk tahap awal, sepertinya lebih baik jangan dijelaskan dulu. Saya juga belum begitu paham. Hehe...
2. JavaScript yang dituliskan secara langsung di dalam halaman yang dipanggil biasanya akan membuat error, sama halnya saat kita mencoba menuliskan tag <script> di dalam JavaScript seperti ini:
<script>
document.write('<script>alert(\'Tidak akan berhasil!\');</script>');
</script>
Setahu Saya masalahnya kebanyakan ada di sekitar itu.
By Taufik Nurrohman, at Monday, February 25, 2013 at 2:32:00 PM GMT+7
ya ya sekitar itu tuh :D
By Beben Koben, at Monday, February 25, 2013 at 6:53:00 PM GMT+7
Saya lihat cara seperti ini jugu digunakan pada infinity scrolling..
dan ada juga yang menggunakan $.ajax () untuk memuat halamannya..
dan hasilnya hampir sama..
By Unknown, at Tuesday, February 26, 2013 at 1:44:00 AM GMT+7
kira2 ada solusi untuk masalah No 2??
By Unknown, at Tuesday, February 26, 2013 at 1:48:00 AM GMT+7
$.get() dan $.getJSON() itu sebenarnya cuma fungsi jalan pintas untuk $.ajax(), dengan tipe data yang sudah ditentukan. Jadi semuanya sama saja.
By Taufik Nurrohman, at Tuesday, February 26, 2013 at 8:31:00 AM GMT+7
Blogspot masih tergantung dengan JavaScript, bahkan untuk formulir komentarnya. Solusinya cuma memakai JSON, bukan memakai HTML blog secara langsung. Meskipun pada contoh di atas Saya berhasil menerapkannya, tapi terkadang hasilnya tidak stabil. Saya tidak bisa menjamin. Masih mencari tahu cara yang paling sederhana.
Kalau mau membuat web dari awal (bukan memakai blogspot, yang —notabene— tidak open source), lebih baik mulai pelajari sudut pandang Hijack terlebih dahulu agar AJAX bisa bekerja dengan mulus:
Begin by creating a website using traditional page refreshes.
Intinya, buat web biasa/tradisional yang bisa bekerja secara normal tanpa JavaScript terlebih dahulu. (Klik link, halaman berganti. Klik link, halaman berganti). Setelah semuanya lancar, barulah AJAX bisa mulai diaplikasikan pada web tersebut.
Ngomong-ngomong, sudah ada blogger yang membuat plugin AJAX untuk blogspot. Instalasinya juga mudah. Tapi mungkin tidak akan bisa bekerja dengan JQuery versi terbaru saat ini. Coba pakai versi 1.7 yang masih mendukung $.browser ⇒ The Wook Book - jQuery Ajaxify Plugin · GitHub
By Taufik Nurrohman, at Tuesday, February 26, 2013 at 9:01:00 AM GMT+7
Wah terima kasih infonya referensinya mas..
sukses selalu mas..
By Unknown, at Tuesday, February 26, 2013 at 1:08:00 PM GMT+7
oh klo sudah menentukan format data yang mau diambil tinggal gunakan $.get() atau $.getJSON().
untuk format data html $.get()
sedangkan JSON/xml $.getJSON()
By Unknown, at Tuesday, February 26, 2013 at 1:13:00 PM GMT+7
kenapa gak langsung elemen #out-shadow nya aja mas misalya di blog mas.biar langsung semua gitu?
By Anonymous, at Tuesday, February 26, 2013 at 2:32:00 PM GMT+7
Kenapa harus dimuat semua kalau yang diperlukan cuma sebagian?
By Taufik Nurrohman, at Tuesday, February 26, 2013 at 4:35:00 PM GMT+7
biar simple aja mas haha
By Anonymous, at Wednesday, February 27, 2013 at 3:34:00 PM GMT+7
Mas apakah cara ini yang di terapkan pihak blogger pada template dinamis
By Unknown, at Wednesday, February 27, 2013 at 7:37:00 PM GMT+7
Syarat tampilan dinamis bisa bekerja adalah feed posting blog tidak boleh dipotong/harus diset ke mode penuh. Itu artinya bahwa AJAX tampilan dinamis Blogger menggunakan JSON dan tidak berinteraksi dengan HTML blog sedikitpun.
By Taufik Nurrohman, at Thursday, February 28, 2013 at 11:44:00 AM GMT+7
mas mau nanya lagi nih..
apa fungsi load atau $.get() dapat memanggil link tanpa akhiran .html??
karena saya coba untuk mendapatkan data dari akun google code misal seperti ini:
$('#judulgooglecode').load('http://code.google.com/p/mini-web-tools/downloads/list #pname span');
atau
$(window).load(function(){
$.get('http://code.google.com/p/mini-web-tools/downloads/list', function(data) {
$('#judulgooglecode').html($(data).find('#pname span'));
});
});
hasilnya tidak muncul..
kira2 di sebelah mana salahnya mas??
By Unknown, at Friday, March 1, 2013 at 3:13:00 AM GMT+7
AJAX cuma berlaku untuk domain lokal. Memuat bagian halaman dari situs lain, memakai cara apapun tetap tidak akan bisa.
By Taufik Nurrohman, at Friday, March 1, 2013 at 7:45:00 AM GMT+7
oh jadi tdk bisa..
By Unknown, at Friday, March 1, 2013 at 12:33:00 PM GMT+7
Post a Comment
<< Home