日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 前端技术 > HTML >内容正文

HTML

HTML地址栏传数据和json区别,前端利用formData格式进行数据上传,前端formData 传值 和 json传值的区别?...

發(fā)布時(shí)間:2025/3/21 HTML 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 HTML地址栏传数据和json区别,前端利用formData格式进行数据上传,前端formData 传值 和 json传值的区别?... 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

contentType 常見(jiàn)的格式

text/plain :純文本格式

application/json: JSON數(shù)據(jù)格式

application/x-www-form-urlencoded 中默認(rèn)的encType,form表單數(shù)據(jù)被編碼為key/value格式發(fā)送到服務(wù)器(表單默認(rèn)的提交數(shù)據(jù)的格式)

multipart/form-data : 需要在表單中進(jìn)行文件上傳時(shí),就需要使用該格

一. json格式傳遞

fetch(url, {

method: 'POST', // or 'PUT'

body: JSON.stringify(data), // data can be `string` or {object}!

headers: new Headers({

'Content-Type': 'application/json' // 需要主動(dòng)設(shè)置,并且將object 用JSON.stringify(data)進(jìn)行轉(zhuǎn)化

})

})

二. From URL Encoded - url 編碼格式 (qs.stringify 格式)

fetch(url, {

method: 'POST', // or 'PUT'

body: qs.stringify(data), // 或者將data轉(zhuǎn)換為formData格式

headers: new Headers({

'Content-Type': 'application/x-www-form-urlencoded' // 不進(jìn)行header設(shè)置的默認(rèn)格式

})

})

三 from 非編碼格式 - Multipart From (文件流的格式)

由于 涉及文件上傳,表單的 提交必須采取非編碼格式 即,'content-type':multipart/form-data;boundary=${boundary};

${boundary} 為一分割字符串。但是,重點(diǎn)來(lái)了,不管事fetch,還是rxjs的 ajax 只要主動(dòng)設(shè)置 content-type為multipart/form-data,不加后面的boundary,會(huì)自動(dòng)加到傳輸?shù)母袷街?#xff0c;導(dǎo)致后端取不到值。如果加了boundary,又導(dǎo)致直接formData都取不到值。

最終解決方案就是,content-type不進(jìn)行設(shè)置,只將data改為 formData格式。瀏覽器會(huì)自動(dòng)識(shí)別,自動(dòng)設(shè)置為content-type:multipart/form-data;boundary=隨機(jī)值 的形式。最終上傳成功。

export const toFormData = (data: Data) => {

if (data === null) return null;

return Object.keys(data).reduce((formData, item) => {

if (item === 'files') { //特殊判斷如果內(nèi)容為files數(shù)組,就讓里面值不用走JSON.stringify

data[item] &&

data[item].forEach((curr) => {

formData.append('upload_file[]', curr.originFileObj);

});

} else {

formData.append(item, JSON.stringify(data[item]));

}

return formData;

}, new FormData());

};

總結(jié):

遇到要傳JSON值,需要手動(dòng)設(shè)置content-type :application/json;

遇到需要傳遞From URL Encoded 格式 formData, 需要 手動(dòng)設(shè)置 content-type:application/x-www-form-urlencoded ,并且使用 qs.stringify (data) 將data轉(zhuǎn)換為url格式,才能正常使用

遇到需要文件流 (Multipart From)格式的formData,需要 手動(dòng)構(gòu)建formData 數(shù)據(jù) ,(new formData,.append('a',1),...), 然后去掉所有的 content-type設(shè)置。也就是 不對(duì)content-type進(jìn)行設(shè)置。利用formData直接作為 post接口的body值,這樣就能正確轉(zhuǎn)化為 'content-type':multipart/form-data;boundary=${boundary} 格式。反正在這種情況下,我實(shí)踐只能是什么都不傳成功了,其他情況都失敗了。使用了fetch和 rxjs的ajax,沒(méi)有使用axios。

總結(jié)

以上是生活随笔為你收集整理的HTML地址栏传数据和json区别,前端利用formData格式进行数据上传,前端formData 传值 和 json传值的区别?...的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: aaaa黄色片 | 日韩一级免费 | 久久综合高清 | 人妻少妇被猛烈进入中文字幕 | 午夜理伦三级做爰电影 | 午夜男人影院 | 久久精品无码中文字幕 | 日韩逼| 日本sm调教—视频|vk | 精品国精品国产自在久不卡 | 一级免费黄色大片 | 日产av在线播放 | 永久免费视频网站直接看 | 4色av| 欧美国产一二三区 | 亚洲日本护士毛茸茸 | 国产一区二区三区影院 | 91精品观看| 天天看片天天干 | www,四虎 | 欧美成人国产 | 91蝌蚪在线观看 | avav亚洲 | 一级全黄裸体免费视频 | 久久久久美女 | 午夜合集 | 国产女主播一区 | 久久久穴 | 乱淫的女高中暑假调教h | 色性网站 | www插插 | 免费网站观看www在线观 | 中文字幕一区二区三区门四区五区 | 亚洲专区一区 | 国产在线观看www | 日本黄色一区二区 | 亚洲午夜在线观看 | 九色porny丨精品自拍视频 | 黄色一级免费片 | 曰批女人视频在线观看 | 色综合欧美 | 四虎网址在线观看 | 婷婷久 | 三上悠亚人妻中文字幕在线 | 在线免费h| 夫妻性生活自拍 | 亚洲欧美国产日韩精品 | 日本少妇激情视频 | 美女高潮网站 | 成人欧美一区二区三区黑人冫 | 欧洲黄色录像 | 99免费看 | 日韩色黄大片 | 欧美综合在线一区 | 色综合色婷婷 | 国产精品成人无码专区 | 国产人妻黑人一区二区三区 | 午夜老司机福利 | 久久久久久久免费 | 久久精品国产99国产 | av基地网 | 浮力影院草草 | 亚洲国产免费视频 | 亚洲性猛交富婆 | 日韩经典在线观看 | 台湾150部性三级 | 午夜影院18 | 最新国产拍偷乱偷精品 | 黑名单上的人全集免费观看 | 成人av在线看 | 日本欧美一本 | 美国av一区二区 | 91九色中文 | 夜夜爽夜夜叫夜夜高潮漏水 | 日韩av片在线免费观看 | 99热99re6国产在线播放 | 午夜精品无码一区二区三区 | 九九视频免费在线观看 | 国产亚洲一区在线 | 日本在线观看网站 | 亚洲av综合色区无码一区爱av | 91色啪 | 伊人久久大 | 97成人精品视频在线观看 | 婷婷激情五月综合 | 蜜桃视频色 | 天堂在线中文资源 | 中文字幕亚洲在线观看 | 国产精品一区二区三区四区在线观看 | 国产一区二区视频在线观看 | 亚洲精品久久久久久宅男 | 国内视频一区二区三区 | 欧美日韩国产成人精品 | 先锋影音av资源站 | 婷婷丁香花五月天 | 免费视频黄色 | 欧美人与性动交g欧美精器 国产在线视频91 | 日韩91av | 免费的黄色的视频 |