Pengenalan terperinci kepada acara dalam jQuery Ajax_jquery
Ajax mencetuskan banyak acara.
Terdapat dua jenis acara, satu acara tempatan dan satu lagi acara global:
Acara tempatan: dipanggil dan diperuntukkan melalui $.ajax.
$.ajax({
beforeSend: function(){
// Kendalikan acara beforeSend
},
Lengkap: function(){
// Kendalikan acara lengkap
}
// ...
});
Peristiwa global boleh diikat menggunakan bind dan unbind boleh digunakan untuk unbind. Ini serupa dengan klik/turun tetikus/keyup dan acara lain. Tetapi ia boleh dihantar kepada setiap elemen DOM.
$("#loading").bind("ajaxSend", function(){ //Gunakan bind
$(this).show();
}).ajaxComplete(function(){ //Gunakan ajaxComplete terus
$(this).hide();
});
Sudah tentu, jika anda tidak mahu acara global dijana untuk permintaan Ajax tertentu, anda boleh menetapkan global:false
$.ajax({
URL: "test.html",
global: palsu,
// ...
});
Jujukan acara adalah seperti berikut:
acara global ajaxStart
Memulakan permintaan Ajax baharu dan tiada permintaan Ajax lain sedang dijalankan pada masa ini.
sebelumHantar acara tempatan
Dipecat apabila permintaan Ajax bermula. Anda boleh menetapkan objek XHR di sini jika perlu.
ajaxSend acara global
Peristiwa global dicetuskan sebelum permintaan bermula
kejayaan acara tempatan
Dicetuskan apabila permintaan berjaya. Iaitu, pelayan tidak mengembalikan ralat, dan data yang dikembalikan tidak mempunyai ralat.
acara global ajaxSuccess
Permintaan global berjaya
ralat acara setempat
Hanya dicetuskan apabila ralat berlaku. Anda tidak boleh melaksanakan kedua-dua fungsi panggil balik kejayaan dan ralat pada masa yang sama.
acara global ajaxError
Dicetuskan secara global apabila ralat berlaku
acara tempatan lengkap
Tidak kira sama ada permintaan anda berjaya atau gagal, walaupun ia adalah permintaan segerak, anda boleh mencetuskan acara ini apabila permintaan itu selesai.
ajaxLengkap acara global
Dicetuskan apabila permintaan global selesai
acara global ajaxStop
Membakar apabila tiada Ajax sedang berjalan.
Parameter panggilan balik acara setempat ditulis dengan jelas dalam dokumentasi, jadi saya tidak akan menerangkan butiran di sini.
Dalam acara global, kecuali ajaxStart dan ajaxStop, acara lain mempunyai 3 parameter
acara, XMLHttpRequest, ajaxOptions
Yang pertama ialah peristiwa, yang kedua ialah objek XHR, dan parameter ketiga adalah yang paling berguna, ia adalah parameter apabila memanggil ajax ini.
Untuk ajaxError, terdapat parameter keempat, thrownError, yang hanya akan diluluskan apabila pengecualian berlaku.
Kita boleh menggunakan ajaxOptions untuk menulis acara ajax global.
Contohnya
$("#msg").beforeSend(function(e,xhr,o) {
$(this).html("Meminta" o.url);
}).ajaxSuccess(fungsi(e,xhr,o) {
$(this).html(o.url "Permintaan berjaya");
}).ajaxError(fungsi(e,xhr,o) {
$(this).html(o.url "Permintaan gagal");
});
Untuk contoh ini,
Dengan cara ini, kami boleh memaparkan status ajax semasa dengan mudah di suatu tempat di seluruh dunia.
Sudah tentu, seperti yang dinyatakan sebelum ini, parameter ketiga sebenarnya adalah parameter yang dihantar kepada ajax. Kaedah seperti get/post/load/getScript/getJSON pada dasarnya memanggil kaedah ajax, jadi atribut ajaxOptions.url sentiasa sah.
Ada banyak lagi contoh.
Jika anda memanggil dengan ajax, anda juga boleh menghantar parameter tersuai. Dalam contoh berikut, saya menyesuaikan parameter mesej untuk panggilan ajax
//Mesej parameter tersuai
$.ajax({url:"test1.html",type:"get",msg:"page one"});
$.ajax({url:"test2.html",type:"get",msg:"Halaman 2"});
$.ajax({url:"test3.html",type:"get",msg:"halaman tiga"});
$.ajax({url:"test4.html",type:"get",msg:"Halaman 4"});
//Di sini anda boleh mendapatkan msg parameter tersuai.
//Ini boleh digunakan untuk merawat permintaan ajax yang berbeza secara berbeza.
$("#msg").beforeSend(function(e,xhr,o) {
$(this).html("Meminta" o.msg);
}).ajaxSuccess(fungsi(e,xhr,o) {
$(this).html(o.msg "Permintaan berjaya");
}).ajaxError(fungsi(e,xhr,o) {
$(this).html(o.msg "Permintaan gagal");
});
Akhir sekali, ada sesuatu untuk dikatakan tentang kaedah beban.
Kaedah ajax mudah lain, seperti get, post, getJSON, dsb., fungsi panggil balik semuanya ditetapkan dengan panggilan balik yang berjaya.
Dan hanya tetapan beban sebenarnya adalah panggilan balik yang lengkap.
Jadi, fungsi panggil balik yang ditetapkan dalam beban harus mempunyai 2 parameter.
XMLHttpRequest dan textStatus
Tetapi sebenarnya tidak begitu.
Panggilan balik beban mempunyai tiga parameter
XMLHttpRequest.responseText, textStatus, XMLHttpRequest
Jadi, anda boleh
dalam panggilan balik beban
Gunakan textStatus=="success" atau textStatus=="error" untuk menentukan sama ada panggilan itu berjaya.
Atau gunakan atribut XMLHttpRequest.status untuk menentukan sama ada ia adalah 200 atau 404 atau sesuatu yang lain.
Dalam hal ini, saya rasa ia lebih maju daripada kaedah get/post biasa. Adalah mustahil untuk menetapkan ralat setiap perolehan dalam nombor ganjil. Tetapi menetapkan ajaxError global sebenarnya adalah pilihan yang baik.

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

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











Bina enjin cadangan autolengkap menggunakan PHP dan Ajax: Skrip sisi pelayan: mengendalikan permintaan Ajax dan mengembalikan cadangan (autocomplete.php). Skrip pelanggan: Hantar permintaan Ajax dan cadangan paparan (autocomplete.js). Kes praktikal: Sertakan skrip dalam halaman HTML dan nyatakan pengecam elemen input carian.

Bagaimana untuk menggunakan kaedah permintaan PUT dalam jQuery? Dalam jQuery, kaedah menghantar permintaan PUT adalah serupa dengan menghantar jenis permintaan lain, tetapi anda perlu memberi perhatian kepada beberapa butiran dan tetapan parameter. Permintaan PUT biasanya digunakan untuk mengemas kini sumber, seperti mengemas kini data dalam pangkalan data atau mengemas kini fail pada pelayan. Berikut ialah contoh kod khusus menggunakan kaedah permintaan PUT dalam jQuery. Mula-mula, pastikan anda memasukkan fail perpustakaan jQuery, kemudian anda boleh menghantar permintaan PUT melalui: $.ajax({u

Tajuk: Petua jQuery: Cepat ubah suai teks semua teg pada halaman Dalam pembangunan web, kita selalunya perlu mengubah suai dan mengendalikan elemen pada halaman. Apabila menggunakan jQuery, kadangkala anda perlu mengubah suai kandungan teks semua teg dalam halaman sekaligus, yang boleh menjimatkan masa dan tenaga. Berikut akan memperkenalkan cara menggunakan jQuery untuk mengubah suai teks semua teg pada halaman dengan cepat, dan memberikan contoh kod khusus. Pertama, kita perlu memperkenalkan fail perpustakaan jQuery dan memastikan bahawa kod berikut dimasukkan ke dalam halaman: <

Menggunakan Ajax untuk mendapatkan pembolehubah daripada kaedah PHP adalah senario biasa dalam pembangunan web Melalui Ajax, halaman boleh diperoleh secara dinamik tanpa menyegarkan data. Dalam artikel ini, kami akan memperkenalkan cara menggunakan Ajax untuk mendapatkan pembolehubah daripada kaedah PHP, dan memberikan contoh kod khusus. Pertama, kita perlu menulis fail PHP untuk mengendalikan permintaan Ajax dan mengembalikan pembolehubah yang diperlukan. Berikut ialah kod contoh untuk fail PHP mudah getData.php:

Tajuk: Gunakan jQuery untuk mengubah suai kandungan teks semua teg jQuery ialah perpustakaan JavaScript yang popular yang digunakan secara meluas untuk mengendalikan operasi DOM. Dalam pembangunan web, kita sering menghadapi keperluan untuk mengubah suai kandungan teks tag pautan (tag) pada halaman. Artikel ini akan menerangkan cara menggunakan jQuery untuk mencapai matlamat ini dan memberikan contoh kod khusus. Pertama, kita perlu memperkenalkan perpustakaan jQuery ke dalam halaman. Tambahkan kod berikut dalam fail HTML:

Ajax (JavaScript Asynchronous dan XML) membenarkan menambah kandungan dinamik tanpa memuatkan semula halaman. Menggunakan PHP dan Ajax, anda boleh memuatkan senarai produk secara dinamik: HTML mencipta halaman dengan elemen kontena dan permintaan Ajax menambah data pada elemen selepas memuatkannya. JavaScript menggunakan Ajax untuk menghantar permintaan kepada pelayan melalui XMLHttpRequest untuk mendapatkan data produk dalam format JSON daripada pelayan. PHP menggunakan MySQL untuk menanyakan data produk daripada pangkalan data dan mengekodnya ke dalam format JSON. JavaScript menghuraikan data JSON dan memaparkannya dalam bekas halaman. Mengklik butang mencetuskan permintaan Ajax untuk memuatkan senarai produk.

jQuery ialah perpustakaan JavaScript popular yang digunakan secara meluas untuk mengendalikan manipulasi DOM dan pengendalian acara dalam halaman web. Dalam jQuery, kaedah eq() digunakan untuk memilih elemen pada kedudukan indeks tertentu Senario penggunaan dan aplikasi khusus adalah seperti berikut. Dalam jQuery, kaedah eq() memilih elemen pada kedudukan indeks yang ditentukan. Kedudukan indeks mula dikira dari 0, iaitu indeks elemen pertama ialah 0, indeks elemen kedua ialah 1, dan seterusnya. Sintaks kaedah eq() adalah seperti berikut: $("s

Untuk meningkatkan keselamatan Ajax, terdapat beberapa kaedah: Perlindungan CSRF: menjana token dan menghantarnya kepada pelanggan, menambahnya ke bahagian pelayan dalam permintaan untuk pengesahan. Perlindungan XSS: Gunakan htmlspecialchars() untuk menapis input bagi mengelakkan suntikan skrip berniat jahat. Pengepala Kandungan-Keselamatan-Dasar: Hadkan pemuatan sumber berniat jahat dan nyatakan sumber dari mana skrip dan helaian gaya dibenarkan untuk dimuatkan. Sahkan input sisi pelayan: Sahkan input yang diterima daripada permintaan Ajax untuk menghalang penyerang daripada mengeksploitasi kelemahan input. Gunakan perpustakaan Ajax yang selamat: Manfaatkan modul perlindungan CSRF automatik yang disediakan oleh perpustakaan seperti jQuery.
