您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“Ajax異步請(qǐng)求如何創(chuàng)建”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Ajax異步請(qǐng)求如何創(chuàng)建”吧!
AJAX(Asynchronous JavaScript and XML):是指一種創(chuàng)建交互式網(wǎng)頁應(yīng)用的網(wǎng)頁開發(fā)技術(shù),通過在后臺(tái)與服務(wù)器進(jìn)行少量數(shù)據(jù)交換,AJAX 可以使網(wǎng)頁實(shí)現(xiàn)異步更新。這就意味著可以在不重新加載整個(gè)網(wǎng)頁的情況下,對(duì)網(wǎng)頁的局部進(jìn)行更新。
const xhr=new XMLHttpRequest();
//get方式 xhr.open('GET',URL); //post方式發(fā)送數(shù)據(jù),需要設(shè)置請(qǐng)求頭 xhr.open('POST',URL); xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
除了method和URL兩個(gè)必選參數(shù)外還有三個(gè)可選參數(shù):flag,name,password
flag:參數(shù)值為布爾類型,用于指定是否用異步方式。true表異步,false表同步,默認(rèn)為true。
name:
//get不需要傳遞參數(shù) xhr.send(null); //post必須有參數(shù) xhr.send('a=100&b=200&c=300');
xhr.onreadystatechange = callback;
function callback() { //判斷響應(yīng)狀態(tài)碼 if(xhr.readyState===4){ // 判斷交互是否成功 if(xhr.status>=200&&xhr.status<300){ // console.log(xhr.status);//狀態(tài)碼 // console.log(xhr.statusText);//狀態(tài)字符串 // console.log(xhr.getAllResponseHeaders());//所有響應(yīng)頭 // console.log(xhr.response);//響應(yīng)體 // 獲取服務(wù)器響應(yīng)的數(shù)據(jù) result.innerHTML=xhr.response; }else{ } } }
ajax中的readyState屬性
0:未初始化。尚未調(diào)用 open()方法。
1:?jiǎn)?dòng)。已經(jīng)調(diào)用 open()方法,但尚未調(diào)用 send()方法。
2:發(fā)送。已經(jīng)調(diào)用 send()方法,但尚未接收到響應(yīng)。
3:接收。已經(jīng)接收到部分響應(yīng)數(shù)據(jù)。
4:完成。已經(jīng)接收到全部響應(yīng)數(shù)據(jù),而且已經(jīng)可以在客戶端使用了。
只有在XMLHttpRequest對(duì)象完成了以上5個(gè)步驟之后,才可以獲取從服務(wù)器端返回的數(shù)據(jù)。
ajax中的狀態(tài)碼(200-300則表示響應(yīng)成功)
400:請(qǐng)求參數(shù)錯(cuò)誤
401:無權(quán)限訪問
404:訪問的資源不存在
案例:獲取天氣信息
格式要求:使用HTML創(chuàng)建一個(gè)輸入框,一個(gè)按鈕,在輸入框中輸入文字后點(diǎn)擊按鈕,即可在下面打印未來15天的天氣
輸出要求:每個(gè)天氣要求:城市名,溫度,天氣,風(fēng)向,風(fēng)力
API網(wǎng)站:(https://www.apishop.net/#/)
APIKEY:***************
使用 $.get( ) 獲取:
var text = $('#text') var btn = $('#button') var div = $('#div1') btn.click(function(){ var city = text.val() var url = "https://api.apishop.net/common/weather/get15DaysWeatherByArea?apiKey=******="+ city $.get(url, function(response){ console.log(response) var list = response.result.dayList; console.log(list) for(var i = 0; i < list.length; i++){ div.append("<ul>") div.append("<li>" + list[i].area + "</li>") div.append("<li>" + list[i].day_air_temperature + "</li>") div.append("<li>" + list[i].day_weather + "</li>") div.append("<li>" + list[i].day_wind_direction + "</li>") div.append("<li>" + list[i].day_wind_power + "</li>") div.append("</ul>") } }, "JSON") })
使用 $.post( ) 獲?。?/p>
var text = $('#text') var btn = $('#button') var div = $('#div1') btn.click(function(){ var url = "https://api.apishop.net/common/weather/get15DaysWeatherByArea?apiKey=******&area=" $.post(url,{ // 傳入必須的參數(shù) area:text.val() }, function(response){ console.log(response) var list = response.result.dayList; console.log(list) for(var i = 0; i < list.length; i++){ div.append("<ul>") div.append("<li>" + list[i].area + "</li>") div.append("<li>" + list[i].day_air_temperature + "</li>") div.append("<li>" + list[i].day_weather + "</li>") div.append("<li>" + list[i].day_wind_direction + "</li>") div.append("<li>" + list[i].day_wind_power + "</li>") div.append("</ul>") } }, "JSON") })
結(jié)果截圖:
到此,相信大家對(duì)“Ajax異步請(qǐng)求如何創(chuàng)建”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。