axios的post請求,數據為什么要用qs處理?什么時候不用?

為什么使用 qs 處理 POST 數據

axios 的 POST 請求默認將 JavaScript 對象序列化為 JSON 格式(Content-Type: application/json)。但某些后端接口(尤其是傳統表單提交)要求數據以 application/x-www-form-urlencoded 格式傳輸,此時需要使用 qs 庫將對象轉換為 URL 編碼的字符串。

qs 的作用是將嵌套對象轉換為鍵值對形式,例如:

{ a: 1, b: { c: 2 } } 
// 轉換為 a=1&b%5Bc%5D=2(即 b[c]=2 的 URL 編碼)

典型場景:

  • 后端接口僅支持 x-www-form-urlencoded 格式。
  • 需要處理多層嵌套對象或數組的復雜數據結構。
  • 需要兼容老式表單提交邏輯。

何時不需要使用 qs

如果接口支持 JSON 格式(現代 API 的常見方式),直接傳遞 JavaScript 對象即可,無需轉換:

axios.post('/api', { name: 'John', age: 30 })
// 自動轉為 JSON:{"name":"John","age":30}

其他情況:

  • 后端明確要求 multipart/form-data(如文件上傳)時,需使用 FormData 對象。
  • 數據本身已是字符串或 URLSearchParams 對象。

代碼示例對比

使用 qs:

import qs from 'qs';
axios.post('/api', qs.stringify({ user: { name: 'John' } }), {headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
});
// 發送數據:user%5Bname%5D=John

不使用 qs:

axios.post('/api', { user: { name: 'John' } });
// 發送數據:{"user":{"name":"John"}}


注意事項

  • 檢查后端接口的 Content-Type 要求。
  • 數組或嵌套對象需確認后端解析規則,qs 可通過配置調整序列化方式(如 qs.stringify({ arr: [1,2] }, { indices: false }) 生成 arr=1&arr=2)。
  • URL 編碼可能存在特殊字符(如 [])的兼容性問題,需與后端對齊。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/88419.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/88419.shtml
英文地址,請注明出處:http://en.pswp.cn/web/88419.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【unitrix】 4.21 類型級二進制數基本結構體(types.rs)

一、源碼 這段代碼定義了一個類型級數值系統的 Rust 實現,主要用于在編譯時表示和操作各種數值類型。 use crate::sealed::Sealed; use crate::number::{NonZero, TypedInt, Unsigned, Primitive}; // // 特殊浮點值枚舉 ///// 特殊浮點值(NaN/∞&#x…

UI前端與數字孿生結合實踐案例:智慧零售的庫存管理優化系統

hello寶子們...我們是艾斯視覺擅長ui設計和前端數字孿生、大數據、三維建模、三維動畫10年經驗!希望我的分享能幫助到您!如需幫助可以評論關注私信我們一起探討!致敬感謝感恩!一、引言:數字孿生重構零售庫存的 “人 - 貨 - 場” 協同在零售行業利潤率持續承壓的背景…

【Freertos實戰】零基礎制作基于stm32的物聯網溫濕度檢測(教程非常簡易)持續更新中.........

本次記錄采用Freertos的第二個DIY作品,基于Onenet的物聯網溫濕度檢測系統,此次代碼依然是全部開源。通過網盤分享的文件:物聯網溫濕度檢測.rar 鏈接: https://pan.baidu.com/s/1uj9UURVtGE6ZB6OsL2W8lw?pwdqm2e 提取碼: qm2e 大家也可以看看…

Matplotlib-多圖布局與網格顯示

Matplotlib-多圖布局與網格顯示一、多圖布局的核心組件二、基礎布局:plt.subplots()快速創建網格1. 均等分網格2. 不等分網格(指定比例)三、進階布局:GridSpec實現復雜嵌套1. 跨行列布局2. 嵌套GridSpec四、實用技巧:布…

GitHub上優秀的開源播放器項目介紹及優劣對比

ExoPlayer 項目地址:https://github.com/google/ExoPlayer 特點: 由Google開發,支持廣泛的視頻格式和流媒體傳輸協議,如DASH、HLS、SmoothStreaming。 提供靈活的媒體源架構和高級特性,如動態自適應流播放。 開發者可以輕松擴展和定制播放器組件,適應特定需求。 優點: 功…

react打包發到線上報錯Minified React error #130

開發過程中遇到一個問題,記錄一下 本地打包發布正常,發測試環境正常,可是通過Jenkins打包發布線上報錯 報錯信息 index-67fbbd81.js:39 Error: Minified React error #130; visit https://reactjs.org/docs/error-decoder.html?invariant130…

微服務項目遠程調用時的負載均衡是如何實現的?

負載均衡概述 負載均衡是微服務架構中的核心組件,用于將請求合理分配到多個服務實例上,提高系統的可用性和性能。負載均衡的分類 負載均衡大致可以分為兩類 1. 服務端負載均衡 實現位置:獨立部署的負載均衡服務器(位于客戶端和服務…

【中文核心期刊推薦】中國農業科技導報

《中國農業科技導報》是中國科技核心期刊,也是北京大學圖書館“中文核心期刊要目總覽”收錄的期刊。它是由中國農村技術開發中心主辦,全面為科教興農服務的綜合性農業學術期刊。《中國農業科技導報》是中國農業科學院生物技術研究所承辦的&a…

php 如何通過mysqli操作數據庫?

在PHP中,mysqli(MySQL Improved Extension)是操作MySQL數據庫的擴展庫,提供了面向對象和過程式兩種風格。以下是mysqli的基本操作方法: 1. 連接數據庫 面向對象風格 $mysqli new mysqli(localhost, username, passwor…

c/c++拷貝函數

memcpy()函數概要原型void * memcpy ( void * dest, const void * src, size_t num );功能memcpy()會復制 src 所指的內存內容的前 num 個字節到 dest所指的內存地址上(memcpy()并不關心被復制的數據類型,只是逐字節地進行復制,這給函數的使用…

HTTP核心基礎詳解(附實戰要點)

目錄 一圖勝千言:HTTP核心機制圖解?編輯 一、HTTP本質:通信的橋梁 二、五大核心特性解析 三、HTTP頭部:隱藏的控制中心 四、連接管理:性能關鍵點 開發者必知實踐技巧 一圖勝千言:HTTP核心機制圖解 一、HTTP本質…

華為靜態路由配置

問題描述:針對兩臺筆記本和兩個路由器在不同的網段場景中,對兩個路由器進行靜態路由配置。下面以如下場景為例,介紹詳細配置過程。配置步驟: 1、對每個路由器的接口下配置IP地址 [huawei]interface gx/x/x [huawei-interface]ip a…

閑庭信步使用圖像驗證平臺加速FPGA的開發:第八課——圖像數據的行緩存

(本系列只需要modelsim即可完成數字圖像的處理,每個工程都搭建了全自動化的仿真環境,只需要雙擊文件就可以完成整個的仿真,大大降低了初學者的門檻!!!!如需要該系列的工程文件請關注…

經典排序算法

文章目錄前言1. 排序的基本概念1.1 排序是什么?1.2 常見的排序算法概覽2. 常見排序算法的實現2.1 插入排序 (Insertion Sort)2.1.1 基本思想2.1.2 直接插入排序2.1.3 希爾排序 (Shell Sort)2.2 選擇排序 (Selection Sort)2.2.1 直接選擇排序2.2.2 堆排序 (Heap Sort…

RabbitMQ 消息隊列:從入門到Spring Boot實戰

RabbitMQ 作為一款開源的、基于 AMQP(Advanced Message Queuing Protocol)協議實現的消息代理,憑借其強大的功能、靈活的路由機制以及出色的性能,在業界得到了廣泛的應用。無論是處理高并發訂單、異步通知、日志收集還是系統解耦&…

代賬行業數字化破局:從“知道”到“做到”,三步走穩贏!

認知!降本!增收!數字化!——這不僅是口號,更是代賬行業在激烈競爭和時代變化中生存發展的關鍵。很多代賬同行其實都明白趨勢,也知道大概該怎么做。但問題卡在第一步:不知道怎么開始,…

Mac 電腦crontab執行定時任務【Python 實戰】

1、crontab -e 編輯定時任務列表 crontab -e查看當前定時任務列表,長按 i 編輯,編輯完之后按 esc 退出編輯,然后輸入:wq 保存并提出。 如下: (base) charles@zl ~ % crontab -e58 15 * * * /Library/Frameworks/Python.framework/Versions/3.8/bin/python3 /Users/charle…

go go go 出發咯 - go web開發入門系列(三) 項目基礎框架搭建與解讀

go go go 出發咯 - go web開發入門系列(三) 項目基礎框架搭建與解讀 往期回顧 go go go 出發咯 - go web開發入門系列(一) helloworldgo go go 出發咯 - go web開發入門系列(二) Gin 框架實戰指南 前言 如…

【字節跳動】數據挖掘面試題0014:SQL中count(1), count(*), count(列)區別

文章大綱SQL 中 count(1)、count(*)、count(某列) 的區別一、核心定義與行為差異二、示例說明差異三、性能差異與優化四、適用場景建議五、面試應答要點六、索引掃描與全表掃描1. 索引掃描的觸發條件2. 全表掃描的適用場景3. 常見面試問題點Q1:索引掃描一定比全表掃…

Linux面試問題-軟件測試

1、你在上一家公司常用的Linux命令有哪些?答:使用vim/vi編輯文件,使用cat,more,less,head查看文件,使用grep過濾日志中的error,使用ps查看進程,使用top查看實時進程,netstat查看端口…