av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

Vue使用axios圖片上傳遇到的問題

瀏覽:4日期:2022-09-29 11:17:02
目錄FormData是個(gè)什么鬼?在vue和axios的配合下實(shí)戰(zhàn)一波append()set()delete()get() 和 getAll()has()FormData是個(gè)什么鬼?

經(jīng)過多方搜索調(diào)查了解,這個(gè)神奇的東西是XMLHttpRequest Level 2 新增的一個(gè)對(duì)象,于2008年2月提出,可以利用它來提交表單、模擬表單提交,當(dāng)然最大的優(yōu)勢(shì)就是可以上傳二進(jìn)制文件,可以把所有表單元素的name與value組成一個(gè)queryString,提交到后臺(tái)。

劃重點(diǎn): 可以把所有表單元素的name與value組成一個(gè)queryString,提交到后臺(tái)。這不就是后端所謂的轉(zhuǎn)換數(shù)據(jù)格式,按格式提交唄,前后端分離肯定是異步提交,這個(gè)就可以很好的去解決這個(gè)問題!

使用也很soeasy 只需要把 form 表單作為參數(shù)傳入 FormData 構(gòu)造函數(shù)即可!

在vue和axios的配合下實(shí)戰(zhàn)一波

<!-- *.vue組件中的上傳組件 我這里使用的是buefy的vue組件--><form method='post' enctype='multipart/form-data'> <b-field :class='{’has-name’: !!file}'><b-upload v-model='file' @input='getModifyAvatar()'> <span class='file-cta'><b-icon icon='upload'></b-icon><span class='file-label'>Click to upload</span> </span> <span v-if='file'>{{ file.name }} </span> </b-upload> </b-field></form><script> export default {data(){ return {userInfo: ’’, // 通過一個(gè)get請(qǐng)求把用戶相關(guān)信息賦值給它file: null, }},methods: { // 修改頭像 getModifyAvatar(){const formData = new FormData();// 構(gòu)造formData數(shù)據(jù)formData.append(’avatar’, this.file)// 提交put請(qǐng)求getModifyInfo(formData).then(res => { this.userInfo.avatar = res.data.avatar}) },} }</script>

// api.js// 這是我封裝的全局請(qǐng)求方法import { request } from ’../network/request’// 修改用戶頭像export const getModifyInfo = (params) => { return request({url: ’ve_register/1/’,method: ’put’,headers: { ’Content-Type’: ’multipart/form-data’ },data: params })}

看以上代碼,注意發(fā)送請(qǐng)求的時(shí)候一定要設(shè)置請(qǐng)求頭header,如上所示,html表單form中也需要設(shè)置下enctype='multipart/form-data' 否則也是不行的!

通過上面的例子我們目前只用到了FormData的append()方法,網(wǎng)上大部分關(guān)于 FormData 介紹的文章都只提到了append()方法,那么FormData 對(duì)象到底有些什么方法呢?其實(shí)我們console 一下就知道了:

Vue使用axios圖片上傳遇到的問題

console 之后我們有重大的發(fā)現(xiàn),F(xiàn)ormData 對(duì)象竟然有這么多方法,所以還是自己測(cè)試才能發(fā)現(xiàn)真相,下面就對(duì)這些方法一一進(jìn)行講解:

append()

append()方法用于向 FormData 對(duì)象中添加鍵值對(duì):

fd.append(’key1’,'value1');fd.append(’key2’,'value2');

fd是 FormData 對(duì)象,可以新建的空的對(duì)象,也可以是已經(jīng)包含 form 表單或其他鍵值對(duì)。

set()

設(shè)置對(duì)應(yīng)的鍵 key 對(duì)應(yīng)的值 value(s)

fd.set(’key1’,'value1');fd.set(’key2’,'value2');

append() 方法有點(diǎn)類似,這兩者的區(qū)別就是,當(dāng)指定的 key 值存在時(shí),append()方法是將新增的添加的所有的鍵值對(duì)最后,而set()方法將會(huì)覆蓋前面的設(shè)置的鍵值對(duì)。還是通過實(shí)例來對(duì)比,我們?cè)谇懊娴?form 的基礎(chǔ)上 append() 或 set() 新的鍵值對(duì):

fd.append(’name’,'will');

有兩個(gè)key為name的鍵值對(duì):

Vue使用axios圖片上傳遇到的問題

以上就是 append() 和 set() 的區(qū)別。如果設(shè)置的key值不存在,那么兩者的效果是一樣的。

delete()

接收一個(gè)參數(shù),表示你要?jiǎng)h除的 key 值的名字,如果有多個(gè)相同 key 值,會(huì)一并刪除:

fd.append(’name’,’will’);fd.delete(’name’);

form 中的 name 信息以及通過append() 新增的name 的信息都被刪除了。

get() 和 getAll()

接收一個(gè)參數(shù),表示需要查找的 key 的名稱,返回第一個(gè)該 key 對(duì)應(yīng)的 value 值。如果有多個(gè)相同的 key, 而且要返回所有的這個(gè) key 對(duì)應(yīng)的 value 值。

同樣以上面的 form 表單為基礎(chǔ):

fd.append(’name’,’will’);console.log(fd.get(’name’)); // sean

fd.append(’name’,’will’);console.log(fd.getAll(’name’)); // ['sean', 'will']has()

該方法也接收一個(gè)參數(shù),同樣是 key 的名稱,返回一個(gè)Boolean 值, 用來判斷FormData 對(duì)象是否含有該 key。以上面的form為例:

console.log(fd.has(’name’)); // trueconsole.log(fd.has(’Name’)); // false

其他幾個(gè)就不介紹了,大家感興趣的自己去驗(yàn)證下,寫一遍嗎,敲一遍,比看任何文章要來的實(shí)在喲!

如果以上文章對(duì)您有幫助,請(qǐng)給我們的開源項(xiàng)目點(diǎn)點(diǎn)star: github.crmeb.net/u/xingfu 不勝感激!

以上就是Vue使用axios圖片上傳遇到的問題的詳細(xì)內(nèi)容,更多關(guān)于Vue使用axios圖片上傳的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: IOS
相關(guān)文章:
主站蜘蛛池模板: 国产精品久久久爽爽爽麻豆色哟哟 | 国产精品免费大片 | 欧美成人a∨高清免费观看 老司机午夜性大片 | 国产亚洲精品美女久久久久久久久久 | 香蕉久久网 | 一区二区三区四区在线视频 | 免费在线精品视频 | h视频在线观看免费 | 热久久国产 | av成人在线观看 | 色综合美女| 午夜丰满寂寞少妇精品 | 亚洲av毛片成人精品 | 在线免费av观看 | 久久九九免费 | 欧美高清视频一区 | 中文字幕在线观看视频一区 | 中国一级特黄真人毛片免费观看 | 精品久久久久久久久久久久 | 国产高清久久久 | 成年人网站免费 | 国产精品久久久久久久7电影 | 日本成人中文字幕 | 久久久女 | 日韩国产在线观看 | 色婷婷激情综合 | 久久久国产一区二区 | av免费网站在线观看 | 欧美福利视频 | 久久国产精品视频 | 2021狠狠干 | 亚洲成色777777在线观看影院 | 自拍视频网 | 最新毛片网站 | 中文字幕色站 | 国产免费一区二区三区最新6 | 欧美中文在线 | 欧美一级毛片免费观看 | 中文字幕不卡 | 影音先锋中文字幕在线观看 | 国产精品1区2区 |