react中的axios模塊你了解嗎
一、react中axios模塊的使用
1、基于Promise的HTTP庫用在瀏覽器和node.js中
可以提供以下服務(wù):
(1)從瀏覽器中創(chuàng)建XMLHttpRequest
(2)從node.js創(chuàng)建http請求
(3)支持PromiseAPI
(4)攔截請求和響應(yīng)
(5)轉(zhuǎn)換請求數(shù)據(jù)和響應(yīng)數(shù)據(jù)
(6)取消請求
(7)自動轉(zhuǎn)換JSON數(shù)據(jù)
(8)客戶端支持防御XSRF
2、創(chuàng)建XMLHttpRequest對象:
該對象是ajax(異步請求)的核心
3、在react中安裝axios
npm install axios
4、發(fā)起不帶參數(shù)的get請求
方式一:axios({ methods: 'get', url: '/ulr' }).then(res => {//請求成功后的處理
console.log(res)
}).catch(err => {//請求失敗后的處理
console.error(err);
})'res'是服務(wù)器返回的響應(yīng)數(shù)據(jù)
err是請求失敗后的信息
方式二:axios.get('/url').then(res => {
console.log(res)
}).catch(err => {
console.error(err);
})5、帶參數(shù)的get請求
在服務(wù)器端獲取請求參數(shù)的方式--> req(request).query.參數(shù)名
方式一: axios.get('/url', {params: {id: 12}}).then(res => {
console.log(res)
}).catch(err => {
console.error(err);
})
//請求的地址實際為:http://localhost:8080/url?id=12方式二:axios({
methods: 'get',
url: 'url',
params: {
id:12 //'id'為參數(shù)名
}
}).then(res => {
console.log(res)
}).catch(err => {
console.error(err);
})6、post請求:發(fā)送表單數(shù)據(jù)和文件上傳
(1)不帶參數(shù)的post請求
方法一:axios({
method:'post',
url:'/url'
}).then(res=>{})
.catch(err=>{})方法二:axios.post('url')
.then(res=>{})
.catch(err=>{})(2)帶參數(shù)的post請求:在服務(wù)器端獲取請求參數(shù)的方式-->req.body.參數(shù)名
服務(wù)器端使用req.body.參數(shù)名 獲取數(shù)據(jù)
let data = {}
let config = {}
方式一: axios.post('/url',{id:12}).then(res => {
console.log(res)
}).catch(err => {
console.error(err);
})方式二: axios({
methods: 'post',
url: '/url',
data: {id:12}
}).then(res => {
console.log(res)
}).catch(err => {
console.error(err);
})7、put請求
和post請求類似
8、delete請求
(1)可以像get請求一樣包裝請求參數(shù):在服務(wù)器端獲取請求參數(shù)的方式--req.query.參數(shù)名
參數(shù)在url的params中:服務(wù)器端使用req.query.參數(shù)名 獲取數(shù)據(jù)
axios.delete('/url', {
params: {id: 12} //'id'為參數(shù)名
}).then(res => {
console.log(res)
}).catch(err => {
console.error(err);
})(2)可以像post請求一樣包裝請求參數(shù):在服務(wù)器端獲取請求參數(shù)的方式--req.body.參數(shù)名
參數(shù)在請求體(post)中 將params改為 data就行:服務(wù)器端使用req.body.參數(shù)名 獲取數(shù)據(jù)
axios.delete('/url', {
data: {id: 12} //'id'為參數(shù)名
}).then(res => {
console.log(res)
}).catch(err => {
console.error(err);
})強調(diào):axios的響應(yīng)結(jié)構(gòu)
后臺: res.json(result) //發(fā)送了json格式的數(shù)據(jù)
相當(dāng)于:{ data: result }
前端: res.data
例如:
后臺:
res.json({
code:1001,
msg: '小森'
})前端:
res.data.code
res.data.msg
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
react實現(xiàn)頭部導(dǎo)航,選中狀態(tài)底部出現(xiàn)藍色條塊問題
這篇文章主要介紹了react實現(xiàn)頭部導(dǎo)航,選中狀態(tài)底部出現(xiàn)藍色條塊問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11
關(guān)于?React?中?useEffect?使用問題淺談
本文主要介紹了關(guān)于React中useEffect使用問題淺談,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
flouting?ui定位組件完美替代ant?deisgn使用詳解
這篇文章主要為大家介紹了flouting?ui定位組件完美替代ant?deisgn使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11
解析React?ref?命令代替父子組件的數(shù)據(jù)傳遞問題
這篇文章主要介紹了React?-?ref?命令為什么代替父子組件的數(shù)據(jù)傳遞,使用?ref?之后,我們不需要再進行頻繁的父子傳遞了,子組件也可以有自己的私有狀態(tài)并且不會影響信息的正常需求,這是為什么呢?因為我們使用了?ref?命令的話,ref是可以進行狀態(tài)的傳輸2022-08-08

