


Adakah ajax segerak atau tak segerak secara lalai?
Ajax lalai kepada penyerahan tak segerak; AJAX dibahagikan kepada "salah" segerak dan "benar" tak segerak mengikut nilai tak segerak, dan secara lalai nilai tak segerak adalah benar (serahan tak segerak). Kelebihan ini ialah ia boleh meningkatkan pengalaman pengguna melalui penyegaran separa, di samping menjimatkan sumber dan mengurangkan tekanan pada pangkalan data.
Persekitaran pengendalian tutorial ini: sistem Windows 7, versi JavaScript 1.8.5, komputer Dell G3.
Kaedah penyerahan lalai ajax ialah penyerahan tak segerak Kelebihan ini ialah ia boleh meningkatkan pengalaman pengguna melalui penyegaran separa, sambil juga menjimatkan sumber dan mengurangkan tekanan pada pangkalan data.
Mengikut nilai async, AJAX dibahagikan kepada segerak (async = false) dan asynchronous (async = true)
$.ajax({ type: "post", url: "path", cache:false, async:false, dataType: ($.browser.msie) ? "text" : "xml", success: function(xmlobj){ function1(){}; } }); function2(){};
Secara lalai, async adalah benar (asynchronous submission).
Cara menukarnya kepada penyegerakan ialah menukar nilai lalai async kepada false, yang biasanya benar atau tidak ditulis Jika ia ditukar kepada palsu, fungsi ajax akan hilang.
1. Apakah permintaan segerak: (salah)
Permintaan segerak bermakna selepas permintaan semasa dikeluarkan, penyemak imbas tidak boleh berbuat apa-apa dan mesti menunggu sehingga permintaan selesai dan dikembalikan Selepas data dikumpul, kod berikutnya akan dilaksanakan, yang bersamaan dengan beratur Orang sebelumnya telah menyelesaikan urusannya sendiri sebelum orang seterusnya boleh meneruskan. Maksudnya, apabila kod JS dimuatkan ke dalam AJAX semasa, semua kod dalam halaman akan berhenti dimuatkan, dan halaman akan berada dalam keadaan animasi yang digantung Apabila AJAX selesai, ia akan terus menjalankan yang lain kod dan halaman akan mengeluarkan keadaan animasi yang digantung (iaitu, apabila ajax kembali Selepas menerima data, fungsi berikut 2) dilaksanakan.
2. Apakah permintaan tak segerak: (benar)
Permintaan tak segerak ialah apabila permintaan dibuat oleh Ajax menghantar permintaan. Ia akan menjejaskan pemuatan halaman dan operasi pengguna.
Secara amnya nilai lalai adalah benar, tak segerak. Permintaan tak segerak tidak menjejaskan pengalaman pengguna sama sekali Tidak kira berapa lama atau pendek permintaan itu, pengguna menumpukan perhatian pada mengendalikan kandungan lain pada halaman dan tidak berasa seperti menunggu.
Apakah perbezaan antara segerak dan tak segerak:
Asynchronous: Dalam mod tak segerak, selepas kami menggunakan AJAX untuk menghantar permintaan, mungkin terdapat kod yang perlu dilaksanakan. Pada masa ini, pelayan mungkin tidak membalas permintaan kami atas pelbagai sebab, tetapi kerana kami menggunakan pelaksanaan tak segerak, kod yang tinggal dalam semua fungsi yang mengandungi kod permintaan AJAX akan terus dilaksanakan. Jika kita menyerahkan hasil permintaan kepada fungsi JS yang lain untuk diproses, maka ia akan menjadi seperti dua utas yang dilaksanakan pada masa yang sama.
Penyegerakan: Dalam mod segerak, selepas kami menggunakan AJAX untuk menghantar permintaan, masih terdapat kod yang perlu dilaksanakan kemudian Kami juga menyerahkan respons pelayan kepada fungsi JS yang lain untuk diproses, tetapi pelaksanaan kod pada masa ini Ya: Apabila pelayan tidak bertindak balas atau fungsi JS yang memproses hasil respons belum memproses pulangan, kod baki fungsi yang mengandungi kod permintaan tidak boleh dilaksanakan. Sama seperti satu utas, ia memasuki keadaan menyekat selepas permintaan dikeluarkan, dan kod yang selebihnya tidak akan terus dilaksanakan sehingga ia mencapai keadaan disekat.
Lihat kod berikut:
var flag=true; var index=0; $.ajax({ url: "", success: function(data){ flag=false; } }); while(flag){ index++; } alert(index);
Akhirnya program memasuki gelung tak terhingga
Lihat kod berikut:
var flag=true; $.ajax({ url: "", success: function(data){ flag=false; } }); alert(flag);
Keputusan akhir Benar
js adalah satu utas Memandangkan melaksanakan permintaan ajax akan mengambil masa tertentu, malah kegagalan rangkaian berlaku dan hasilnya tidak dikembalikan pada masa ini , jika ia dilaksanakan secara serentak, anda mesti menunggu sehingga ajax Kod seterusnya hanya boleh dilaksanakan selepas keputusan dikembalikan Jika permintaan ajax mengambil masa 1 minit, program perlu menunggu selama 1 minit. Jika ia dilaksanakan secara tak segerak, sementara menunggu pelayan kembali, latar depan akan terus melaksanakan skrip di belakang blok ajax Kejayaan tidak akan dilaksanakan sehingga pelayan mengembalikan hasil normal Pada masa ini, dua utas dilaksanakan, ajax Selepas blok membuat permintaan, benang dan skrip di belakang blok ajax
var flag=true; var index=0; $.ajax({ url: "", async:false, success: function(data){ flag=false; } }); while(flag){ index++; } alert(index);
Hasil akhir ialah 0
[Cadangan tutorial berkaitan: Tutorial video AJAX]
Atas ialah kandungan terperinci Adakah ajax segerak atau tak segerak secara lalai?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

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



Tajuk: Kaedah dan contoh kod untuk menyelesaikan ralat 403 dalam permintaan AJAX jQuery Ralat 403 merujuk kepada permintaan bahawa pelayan melarang akses kepada sumber Ralat ini biasanya berlaku kerana permintaan itu tidak mempunyai kebenaran atau ditolak oleh pelayan. Apabila membuat permintaan jQueryAJAX, anda kadangkala menghadapi situasi ini Artikel ini akan memperkenalkan cara menyelesaikan masalah ini dan memberikan contoh kod. Penyelesaian: Semak kebenaran: Mula-mula pastikan alamat URL yang diminta adalah betul dan sahkan bahawa anda mempunyai kebenaran yang mencukupi untuk mengakses sumber tersebut.

jQuery ialah perpustakaan JavaScript popular yang digunakan untuk memudahkan pembangunan sisi klien. AJAX ialah teknologi yang menghantar permintaan tak segerak dan berinteraksi dengan pelayan tanpa memuatkan semula keseluruhan halaman web. Walau bagaimanapun, apabila menggunakan jQuery untuk membuat permintaan AJAX, anda kadangkala menghadapi 403 ralat. Ralat 403 biasanya ralat akses yang dinafikan pelayan, mungkin disebabkan oleh dasar keselamatan atau isu kebenaran. Dalam artikel ini, kami akan membincangkan cara menyelesaikan permintaan jQueryAJAX yang menghadapi ralat 403

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:

Bagaimana untuk menyelesaikan masalah jQueryAJAX ralat 403? Apabila membangunkan aplikasi web, jQuery sering digunakan untuk menghantar permintaan tak segerak. Walau bagaimanapun, kadangkala anda mungkin menghadapi kod ralat 403 apabila menggunakan jQueryAJAX, menunjukkan bahawa akses dilarang oleh pelayan. Ini biasanya disebabkan oleh tetapan keselamatan bahagian pelayan, tetapi terdapat cara untuk mengatasinya. Artikel ini akan memperkenalkan cara menyelesaikan masalah ralat jQueryAJAX 403 dan memberikan contoh kod khusus. 1. membuat

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.

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.

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.

Ajax bukanlah versi khusus, tetapi teknologi yang menggunakan koleksi teknologi untuk memuatkan dan mengemas kini kandungan halaman web secara tidak segerak. Ajax tidak mempunyai nombor versi tertentu, tetapi terdapat beberapa variasi atau sambungan ajax: 1. jQuery AJAX 2. Axios 4. JSONP 5. XMLHttpRequest 7. Server; -Acara Dihantar; 8, GraphQL, dsb.
