前端傳參的三種方式實(shí)戰(zhàn)案例
1、params 傳參
參數(shù)拼接在地址 url 的后面給后臺;地址欄中可見
案例1
地址欄:https://xxxxxxxx/admin/clues/detail?id=558
接口代碼:
export function getClueDetail(query: any) { return request<clueItem>({ url: '/clues/detail', method: 'get', params: query }) }
對于這個(gè)接口而言,query是接口被調(diào)用時(shí)接收參數(shù)的形參;params即是傳參方式,而query就是參數(shù),其會自動拼接在請求地址的 url 后面,以問號分隔,數(shù)據(jù)之間通過&連接;這樣我們可以直接在地址欄中看到請求的參數(shù)
案例2
地址欄: http://192.168.7.188:3000/registers/list?name=&mobile=&IDNumber=&page=1&perPage=10000
export function getPeopleList(query) { return request({ url: "/registers/list", method: "get", params: query, }); }
在本接口中 query 中就是查詢參數(shù),其中包含了很多個(gè)參數(shù);
2、data 傳參
使用 data 傳參,其會把數(shù)據(jù)拼接在請求體里 (body參數(shù));地址欄中看不到請求參數(shù)
案例3
export function postClueCreate(data: clueItem) { return request<clueItem>({ url: '/clues/create', method: 'POST', data: data }) }
在控制臺中可以打印出來(這里不僅可以展示 data傳參中的參數(shù),也可以展示params傳參中的參數(shù))
3、headers 傳參
headers 傳參 方式 用的比較少
import axios from 'axios' import store from '@/store' const myAxios = axios.create({ // 基地址 baseURL: 'http://xxxxxx' }) const getUserInfoAPI = () => { return request({ url: '/my/userinfo' // method不寫默認(rèn)就是'get'方式請求 headers: { Authorization: store.state.token } }) }
案例4 (項(xiàng)目實(shí)操案例)
一個(gè)接口 同時(shí)使用 params和data 這兩種傳參方式
params的參數(shù)會拼接在地址欄中,而data中的參數(shù)會拼接在請求體body中,可以在控制臺看到二者
接口
export function updatePeople(data) { return request({ url: "/registers/update", method: "post", // 從data中取出想要的參數(shù),裝入params中 params: { id: data.id, }, // data 直接照單全收 data: data, }); }
地址欄:
參數(shù)
附:前端傳參后端沒接到什么原因
前端傳參后端沒接到可能有多種原因,以下是一些常見的情況:
前端傳參的方式不正確,例如使用 GET 方法傳參時(shí),參數(shù)沒有放在 URL 中;使用 posT 方法傳參時(shí),參數(shù)沒有放在請求體中。
前端傳參時(shí)參數(shù)名稱不正確或者參數(shù)值為空,這可能會導(dǎo)致后端無法正確解析參數(shù)。
后端接收參數(shù)的方式不正確,例如使用 GET 方法接收參數(shù)時(shí),沒有正確解析 URL 中的參數(shù);使用 posT 方法接收參數(shù)時(shí),沒有正確解析請求體中的參數(shù)。
后端的接口地址不正確,導(dǎo)致前端傳參的數(shù)據(jù)沒有正確發(fā)送到后端。
網(wǎng)絡(luò)通信問題,例如前端請求被防火墻攔截、網(wǎng)絡(luò)超時(shí)等情況,導(dǎo)致前端傳參后端接收失敗。
總結(jié)
到此這篇關(guān)于前端傳參的三種方式的文章就介紹到這了,更多相關(guān)前端傳參方式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS+CSS實(shí)現(xiàn)自動改變切換方向圖片幻燈切換效果的方法
這篇文章主要介紹了JS+CSS實(shí)現(xiàn)自動改變切換方向圖片幻燈切換效果的方法,實(shí)例分析了javascript操作圖片切換方向的幻燈片技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03setTimeout的延時(shí)為0時(shí)多個(gè)瀏覽器的區(qū)別
一直比較迷惑:js的setTimeout到底會在什么時(shí)候執(zhí)行,如果執(zhí)行了,和主執(zhí)行腳本到底差多長時(shí)間2012-05-05高性能web開發(fā) 如何加載JS,JS應(yīng)該放在什么位置?
所有瀏覽器在下載JS的時(shí)候,會阻止一切其他活動,比如其他資源的下載,內(nèi)容的呈現(xiàn)等等。至到JS下載、解析、執(zhí)行完畢后才開始繼續(xù)并行下載其他資源并呈現(xiàn)內(nèi)容。2010-05-05JavaScript實(shí)現(xiàn)水印效果的示例代碼
這篇文章主要為大家詳細(xì)介紹了JavaScript如何利用canvas實(shí)現(xiàn)添加水印的效果,文中的示例代碼簡潔易懂,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-05-05