Postman的FormData傳參的使用示例詳解
今年上半年因?yàn)樽霎呍O(shè)的原因,有自己接觸到后端,也是用過了postman去測(cè)試接口,看到了postman那邊的參數(shù)形式,一直對(duì)這個(gè)formData有想法。
在做畢設(shè)前后端對(duì)接接口過程中,一般get或者delete請(qǐng)求我都會(huì)使用url拼接的形式,因?yàn)楦鶕?jù)restAPI格式,這兩者我基本上都是拿來獲取某個(gè)東西的詳情信息,或者刪除某個(gè)東西的詳情信息,而至于最經(jīng)常使用到的post請(qǐng)求,我一般使用的都是采取json格式的語(yǔ)法進(jìn)行傳參在json里前端只要傳過去對(duì)應(yīng)的對(duì)象即可,但是一直對(duì)于這個(gè)formData這個(gè)傳參方式有點(diǎn)誤解,聽名字感覺像是表單傳參過去的。
一.創(chuàng)建一個(gè)formData對(duì)象實(shí)例的方式
1、創(chuàng)建一個(gè)空對(duì)象
var formData = new FormData();//通過append方法添加數(shù)據(jù)
2、使用已有表單來初始化對(duì)象
//表單示例
<form id="myForm" action="" method="post">
<input type="text" name="name">名字
<input type="password" name="psw">密碼
<input type="submit" value="提交">
</form>
//方法示例
// 獲取頁(yè)面已有的一個(gè)form表單
var form = document.getElementById("myForm");
// 用表單來初始化
var formData = new FormData(form);
// 我們可以根據(jù)name來訪問表單中的字段
var name = formData.get("name"); // 獲取名字
var psw = formData.get("psw"); // 獲取密碼
// 當(dāng)然也可以在此基礎(chǔ)上,添加其他數(shù)據(jù)
formData.append("token","kshdfiwi3rh");二. 操作方法
formData里面存儲(chǔ)的數(shù)據(jù)是以健值對(duì)的形式存在的,key是唯一的,一個(gè)key可能對(duì)應(yīng)多個(gè)value。
如果是使用表單初始化,每一個(gè)表單字段對(duì)應(yīng)一條數(shù)據(jù),它們的HTML name屬性即為key值,它們value屬性對(duì)應(yīng)value值。
1.獲取值
//通過get(key)/getAll(key)來獲取對(duì)應(yīng)的value
formData.get("name"); // 獲取key為name的第一個(gè)值
formData.get("name"); // 返回一個(gè)數(shù)組,獲取key為name的所有值2 添加數(shù)據(jù)
//通過append(key, value)來添加數(shù)據(jù),如果指定的key不存在則會(huì)新增一條數(shù)據(jù),如果key存在,則添加到數(shù)據(jù)的末尾
formData.append("k1", "v1");
formData.append("k1", "v2");
formData.append("k1", "v3");獲取值時(shí)方式及結(jié)果如下:
formData.get("k1"); // "v1"
formData.getAll("k1"); // ["v1","v2","v3"]
3.設(shè)置修改數(shù)據(jù)
//set(key, value)來設(shè)置修改數(shù)據(jù),如果指定的key不存在則會(huì)新增一條,如果存在,則會(huì)修改對(duì)應(yīng)的value值
formData.append("k1", "v1");
formData.set("k1", "1");
formData.getAll("k1"); // ["1"]4.判斷是否存在對(duì)應(yīng)數(shù)據(jù)
//has(key)來判斷是否對(duì)應(yīng)的key值
formData.append("k1", "v1");
formData.append("k2",null);
formData.has("k1"); // true
formData.has("k2"); // true
formData.has("k3"); // false5.刪除數(shù)據(jù)
//delete(key)刪除數(shù)據(jù)
formData.append("k1", "v1");
formData.append("k1", "v2");
formData.append("k1", "v1");
formData.delete("k1");
formData.getAll("k1"); // []三.JQuery實(shí)例
//添加數(shù)據(jù)方式見上二。
//processData: false, contentType: false,多用來處理異步上傳二進(jìn)制文件。
$.ajax({
url: 'xxx',
type: 'POST',
data: formData, // 上傳formdata封裝的數(shù)據(jù)
dataType: 'JSON',
cache: false, // 不緩存
processData: false, // jQuery不要去處理發(fā)送的數(shù)據(jù)
contentType: false, // jQuery不要去設(shè)置Content-Type請(qǐng)求頭
success:function (data) { //成功回調(diào)
console.log(data);
}
});·
/**
* 將以base64的圖片url數(shù)據(jù)轉(zhuǎn)換為Blob文件格式
* @param urlData 用url方式表示的base64圖片
*/
function convertBase64UrlToBlob(urlData) {
var bytes = window.atob(urlData.split(',')[1]); //去掉url的頭,并轉(zhuǎn)換為byte
//處理異常,將ascii碼小于0的轉(zhuǎn)換為大于0
var ab = new ArrayBuffer(bytes.length);
var ia = new Uint8Array(ab);
for(var i = 0; i < bytes.length; i++) {
ia[i] = bytes.charCodeAt(i);
}
return new Blob([ab], {
type: 'image/png'
});
}以上是我對(duì)FormData的理解和使用。
到此這篇關(guān)于Postman的FormData傳參用法詳解的文章就介紹到這了,更多相關(guān)Postman的FormData傳參內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS實(shí)現(xiàn)簡(jiǎn)易留言板(節(jié)點(diǎn)操作)
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)簡(jiǎn)易留言板,節(jié)點(diǎn)進(jìn)行操作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03
利用原生JavaScript實(shí)現(xiàn)造日歷輪子實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于如何利用原生JavaScript實(shí)現(xiàn)造日歷輪子的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
淺談JavaScript Math和Number對(duì)象
這篇文章主要簡(jiǎn)單介紹了JavaScript Math和Number對(duì)象的相關(guān)資料,需要的朋友可以參考下2015-01-01
JavaScript雙向鏈表實(shí)現(xiàn)LRU緩存算法的示例代碼
本文主要介紹了JavaScript雙向鏈表實(shí)現(xiàn)LRU緩存算法的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
javascript 節(jié)點(diǎn)排序?qū)崿F(xiàn)代碼
為了讓自定義選擇選擇出的節(jié)點(diǎn)集合盡可能接近原生API選出的結(jié)果,我們往往要對(duì)結(jié)果集進(jìn)行排序,此順序當(dāng)然是從上到下,從左到右的DOM樹順序。2011-01-01
淺談JavaScript的push(),pop(),concat()方法
下面小編就為大家?guī)硪黄獪\談JavaScript的push(),pop(),concat()方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06

