在 web 開發(fā)中,我們常常需要從前端發(fā)送 HTTP 請(qǐng)求獲取一些數(shù)據(jù)。有時(shí)候我們需要像發(fā)送表單一樣將一些參數(shù)傳遞給后端,而經(jīng)常使用的方法之一就是在 URL 中添加查詢參數(shù),這些參數(shù)可以通過 get 請(qǐng)求來獲取。而為了讓請(qǐng)求的參數(shù)具有結(jié)構(gòu)化的形式,通常會(huì)將參數(shù)以 JSON 格式的字符串的形式添加在 URL 中。
https://example.com/api/getData?data={"name": "Tom", "age": 18, "gender": "male"}
上面的示例中,我們?cè)诎l(fā)送 GET 請(qǐng)求時(shí),將一個(gè) JSON 字符串作為參數(shù)添加在了 URL 的末尾。后端通過解析這個(gè) JSON 字符串,就可以得到我們傳遞的數(shù)據(jù)。
對(duì)于前端開發(fā)者而言,獲取這種參數(shù)也非常簡(jiǎn)單,只需要通過解析 URL 獲取參數(shù),并將 JSON 字符串解析為 JavaScript 對(duì)象即可:
const urlParams = new URLSearchParams(window.location.search); const data = JSON.parse(urlParams.get('data')); console.log(data.name); // 輸出 "Tom"
總之,通過 GET 參數(shù)傳遞 JSON 數(shù)據(jù)是一種非常常見的技術(shù),在實(shí)際開發(fā)中也經(jīng)常會(huì)使用到。我們只需要在前后端之間協(xié)商好參數(shù)的名稱和格式,就可以方便地傳遞數(shù)據(jù)了。