網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
前言
AJAX(Asynchronous JavaScript and XML):是指一種創(chuàng)建交互式網(wǎng)頁(yè)應(yīng)用的網(wǎng)頁(yè)開(kāi)發(fā)技術(shù),通過(guò)在后臺(tái)與服務(wù)器進(jìn)行少量數(shù)據(jù)交換,AJAX 可以使網(wǎng)頁(yè)實(shí)現(xiàn)異步更新。這就意味著可以在不重新加載整個(gè)網(wǎng)頁(yè)的情況下,對(duì)網(wǎng)頁(yè)的局部進(jìn)行更新。
1.建立xmlHttpRequest異步對(duì)象
const xhr=new XMLHttpRequest();
2.創(chuàng)建HTTP請(qǐng)求(設(shè)置請(qǐng)求方法和URL)
//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ù)值為布爾類(lèi)型,用于指定是否用異步方式。true表異步,false表同步,默認(rèn)為true。
name:
3.發(fā)送數(shù)據(jù)
//get不需要傳遞參數(shù)
xhr.send(null);
//post必須有參數(shù)
xhr.send('a=100&b=200&c=300');
4.設(shè)置回調(diào)函數(shù)
xhr.onreadystatechange = callback;
5.在回調(diào)函數(shù)中對(duì)不同的響應(yīng)狀態(tài)進(jìn)行處理
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:無(wú)權(quán)限訪問(wèn)
- 404:訪問(wèn)的資源不存在
案例實(shí)現(xiàn)
案例:獲取天氣信息
格式要求:使用HTML創(chuàng)建一個(gè)輸入框,一個(gè)按鈕,在輸入框中輸入文字后點(diǎn)擊按鈕,即可在下面打印未來(lái)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( ) 獲取:
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é)果截圖:
總結(jié)
原文鏈接:https://blog.csdn.net/qq_62380657/article/details/124597221
相關(guān)推薦
- 2022-05-03 C#面向?qū)ο笤O(shè)計(jì)原則之接口隔離原則_C#教程
- 2022-08-03 python判定文件目錄是否存在及創(chuàng)建多層目錄_python
- 2022-10-11 ArrayList源碼中的MAX_ARRAY_SIZE
- 2022-09-23 基于numpy實(shí)現(xiàn)邏輯回歸_python
- 2022-05-28 C++?數(shù)據(jù)結(jié)構(gòu)超詳細(xì)講解單鏈表_C 語(yǔ)言
- 2022-08-30 如何解決React?useEffect鉤子帶來(lái)的無(wú)限循環(huán)問(wèn)題_React
- 2022-04-08 Android統(tǒng)一依賴管理的三種方式總結(jié)_Android
- 2022-07-20 用C語(yǔ)言實(shí)現(xiàn)掃雷
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支