午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

javascript - 如何使用formData上傳file數組

瀏覽:214日期:2023-02-21 09:34:42

問題描述

因為 input type=‘file’ 再次點擊會將之前的fileList覆蓋,所以我先將選中的文件轉成base64作為預覽圖片,類似于這樣,可以多次添加

javascript - 如何使用formData上傳file數組

但是我在上傳的時候如何將多個預覽圖片添加到 formdata 對象中,后臺接受參數是一個 MultipartFile[] files 數組。

下面是我的錯誤做法:

function getImgFiles() { var imgFiles = []; var imgs = $(’img’); $.each(imgs, function (i, item) {var blob = dataURItoBlob(item.src);imgFiles.push(new File([blob], item.id)); }); return imgFiles;}/** * base64->blob * @param dataURI * @returns {Blob} */function dataURItoBlob(dataURI) { var byteString = atob(dataURI.split(’,’)[1]); var mimeString = dataURI.split(’,’)[0].split(’:’)[1].split(’;’)[0]; var ab = new ArrayBuffer(byteString.length); var ia = new Uint8Array(ab); for (var i = 0; i < byteString.length; i++) {ia[i] = byteString.charCodeAt(i); } return new Blob([ab], {type: mimeString});}var formData = new FormData($(’form’).get(0));formData.append(’files’, getImgFiles());//然后使用ajax上傳,但是后臺沒有接受到 files 參數。

問題解答

回答1:

可以有以下幾種做法:

$.each(getImgFiles(), function(i, file){ formData.append(’files’, file);});

$.each(getImgFiles(), function(i, file){ formData.append(’files[]’, file);});

$.each(getImgFiles(), function(i, file){ formData.append(’files_’ + i, file);});

都應該可以在后臺接收到文件。而具體用哪種做法要看你后臺所使用的語言和框架。

就PHP而言,我喜歡最后一種,可以用 $_FILES 一次遍歷就能獲取到所有的文件/圖片。

回答2:

每次把文件轉出base64的時候,順帶也出個blob,順手append到你的formData結構里就行了。

另外我記得input可以支持多選的吧?

回答3:

你先F12在network里面看看這條請求里面的參數有沒有

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 啪啪自拍 | 亚洲午夜视频在线 | 国产精品国产三级国产a | 久久两性视频 | 毛片网在线观看 | 老女人呻吟高潮 | 亚洲欧美视频在线观看 | 日本天堂免费 | 欧美成人自拍视频 | 亚洲免费观看高清 | 男女同房做爰123 | 国产精品一级 | 中文字幕在线精品 | 日本精品视频一区二区三区 | 可以免费观看的av | 四虎国产成人永久精品免费 | 一级午夜 | 久久久久久国产精品视频 | 亚洲黄色在线免费观看 | 日韩无| 国产精品久久91 | 成年人在线观看视频网站 | 北条麻妃青青久久 | 日韩成人在线网站 | 亚洲欧美国产精品久久久久久久 | 日韩久久中文字幕 | 国产麻豆精品在线观看 | 深夜福利久久 | 国产在线播放一区二区三区 | 久久在线视频免费观看 | 日韩一级片在线观看 | 香蕉毛片视频 | 欧洲av网站| 在线看一区二区 | 精品一区二区在线观看 | 日韩在线精品强乱中文字幕 | 一本一道波多野结衣一区二区 | 在线观看黄色av | 精品免费国产 | 国产视频1区2区 | 久久久久网站 |