Apakah perbezaan antara ajax dan fetch
Perbezaan antara ajax dan fetch: 1. Seni bina pembangunan ajax berdasarkan XHR asli tidak jelas, dan fetch menggunakan mekanisme pemprosesan tak segerak Promise, yang lebih mudah digunakan daripada ajax 2. ajax menggunakan XMLHttpRequest objek untuk meminta data, dan pengambilan hanya global Satu cara untuk mengukur tetingkap.
Persekitaran pengendalian artikel ini: sistem windows7, versi javascript1.8.5&&&html5, komputer Dell G3.
Apakah perbezaan antara ajax dan fetch
1. Perbezaan antara ajax dan fetch:
(1) Ajax menggunakan objek XMLHttpRequest untuk meminta data, dan fetch ialah kaedah tetingkap
(2) Ajax dibangunkan berdasarkan XHR asli Struktur XHR itu sendiri tidak jelas sudah mengambil alternatif
(3), fetch mempunyai kaedah penulisan yang lebih baik dan lebih mudah berbanding dengan ajax
(4), ambil hanya melaporkan ralat untuk permintaan rangkaian dan menganggap 400 dan 500 sebagai berjaya permintaan , perlu dirangkumkan untuk mengendalikan
(5), fetch tidak mempunyai cara untuk memantau perkembangan permintaan secara asli, tetapi XHR boleh
2.ajax penggunaan
kerana kaedah penulisan aslinya sangat tidak berguna, jadi kebanyakannya akan dirangkumkan, yang mungkin menyebabkan ramai orang tidak dapat menulis permintaan ajax sendiri. Mereka semua menggunakan JQuery atau Axios untuk meminta data
var xhr= new XMLHttpRequest(); // 新建XMLHttpRequest对象xhr.onload= function(){ //请求完成 console.log(this.responseText); }// 发送请求:xhr.open('GET', '/user'); xhr.send();
Permintaan sedemikian dihantar. Ia sangat menyusahkan Anda perlu menulis begitu banyak baris kod untuk menghantar permintaan mudah. Sudah tentu anda tidak akan menulisnya seperti ini dalam pembangunan sebenar, jika tidak, kod akan menjadi berlebihan dan boleh dibaca Gunakan janji untuk merangkumnya
var Ajax = { get: function(url,fn){ // XMLHttpRequest对象用于在后台与服务器交换数据 var xhr=new XMLHttpRequest(); xhr.open('GET',url,false); xhr.onreadystatechange=function(){ // readyState == 4说明请求已完成 if(xhr.readyState==4){ if(xhr.status==200 || xhr.status==304){ console.log(xhr.responseText); fn.call(xhr.responseText); } } } xhr.send(); }, // data应为'a=a1&b=b1'这种字符串格式,在jq里如果data为对象会自动将对象转成这种字符串格式 post: function(url,data,fn){ var xhr=new XMLHttpRequest(); xhr.open('POST',url,false); // 添加http头,发送信息至服务器时内容编码类型 xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded'); xhr.onreadystatechange=function(){ if (xhr.readyState==4){ if (xhr.status==200 || xhr.status==304){ // console.log(xhr.responseText); fn.call(xhr.responseText); } } } xhr.send(data); } }
Komen kod:
1.open(. kaedah, url, async) Kaedah ini memerlukan tiga parameter:
kaedah: kaedah yang digunakan untuk menghantar permintaan (GET atau POST); berbanding dengan POST, GET adalah lebih mudah dan pantas, dan boleh digunakan dalam kebanyakan kes ; walau bagaimanapun, Sila gunakan permintaan POST dalam situasi berikut:
①Fail cache tidak boleh digunakan (mengemas kini fail atau pangkalan data pada pelayan)
②Hantar sejumlah besar data ke pelayan (POST tidak mempunyai had volum data )
③ POST adalah lebih stabil dan boleh dipercayai daripada GET apabila menghantar input pengguna yang mengandungi aksara yang tidak diketahui
url: Menentukan URL skrip sebelah pelayan (fail boleh berupa sebarang jenis fail, seperti . txt dan .xml, atau fail Skrip pelayan, seperti .asp dan .php (boleh melaksanakan tugas pada pelayan sebelum mengembalikan respons)); ) atau serentak (false true) Ia adalah untuk melaksanakan skrip lain sambil menunggu respons pelayan, dan memproses respons apabila respons sedia palsu ialah menunggu respons pelayan sebelum melaksanakan;
Kaedah 2.send() boleh menghantar permintaan ke pelayan.
3.onreadystatechange: Terdapat fungsi yang memproses respons pelayan Apabila readyState berubah, fungsi onreadystatechange akan dilaksanakan.
4.readyState: Menyimpan maklumat status respons pelayan.
0: Permintaan tidak dimulakan (proksi dibuat, tetapi kaedah open() belum dipanggil)
1: Sambungan pelayan telah diwujudkan (kaedah terbuka telah dipanggil)2: Permintaan telah diterima (hantar Kaedah telah dipanggil, dan pengepala serta status tersedia)
3: Permintaan sedang diproses (memuat turun, atribut responseText sudah mengandungi sebahagian daripada data)
4: Permintaan telah selesai dan respons sudah sedia (operasi muat turun telah Selesai)
5.responseText: Dapatkan data respons dalam bentuk rentetan.
6.setRequestHeader(): Apabila POST menghantar data, ia digunakan untuk menambah pengepala HTTP, kemudian menghantar(data), perhatikan format data apabila GET menghantar maklumat, cuma tambah parameter terus ke url , seperti url?a =a1&b=b1.
3.mengambil penggunaan1 Parameter pertama ialah URL
2 Parameter pilihan kedua boleh mengawal objek init yang berbeza3 promise object dalam js
var arr1 = [{ name: "haha", detail:"123"}]; fetch("url", { method: "post", headers: {//设置请求的头部信息 "Content-Type": "application/json" //跨域时可能要加上 //"Accept":"allication/json" }, //将arr1对象序列化成json字符串 body: JSON.stringify(arr1)//向服务端传入json数据 }).then(function(resp) { resp.json().then((data) => { }) });
[Cadangan tutorial berkaitan:
Tutorial video AJAXAtas ialah kandungan terperinci Apakah perbezaan antara ajax dan fetch. 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

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





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

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 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

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:

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.
