這篇文章主要為大家展示了“基于Ajax中formData圖片和數(shù)據(jù)上傳的示例分析”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“基于Ajax中formData圖片和數(shù)據(jù)上傳的示例分析”這篇文章吧。
成都創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站建設(shè)、網(wǎng)站制作、柳州網(wǎng)絡(luò)推廣、小程序開發(fā)、柳州網(wǎng)絡(luò)營銷、柳州企業(yè)策劃、柳州品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);成都創(chuàng)新互聯(lián)公司為所有大學(xué)生創(chuàng)業(yè)者提供柳州建站搭建服務(wù),24小時(shí)服務(wù)熱線:028-86922220,官方網(wǎng)址:www.cdcxhl.com
1、上傳組件
說明一下,項(xiàng)目是基于vue框架的
開心就好的小店
- 首頁
- 返回貨架
- 放棄編輯
- 上架
說明,包含兩個(gè)上傳圖片的組件,前面一個(gè)有multiple為多文件模式,即一次可選擇多張圖片,后面的是單文件模式。
2、接下來是圖片的預(yù)覽
viewimg($event) { //獲取當(dāng)前的input標(biāo)簽 var currentObj = event.currentTarget; //找到要預(yù)覽的圖片img標(biāo)簽,亦可動(dòng)態(tài)生成 var img = currentObj.parentNode.children[0]; setImagePreview(currentObj, img); function setImagePreview(docObj, imgObjPreview) { if (docObj.files && docObj.files[0]) { imgObjPreview.style.display = 'block'; imgObjPreview.src = window.URL.createObjectURL(docObj.files[0]); } } }
這一部分的主要功能是將選中的圖片進(jìn)行展示,當(dāng)然啦,這里并沒有出來多張圖片的情況
3、核心部分,圖片上傳
/*采用formData形式上傳圖片和表單數(shù)據(jù)*/ upload: function() { var _self = this; var formData = new FormData(); var inputs = $("input.fileupload"); for (var i = 0; i < inputs.length; i++) { var file = inputs[i]; if (inputs[i].files[0]) { formData.append("file", file.files[0], file.files[0].name); } } formData.append('barterCommodityname', _self.goodsname); formData.append('barterSellingprice', _self.price); formData.append('barterContactinformation', _self.phone); formData.append('barterCommodityquantity', _self.number); formData.append('barterCommodityaddress', _self.address); formData.append('barterDescriptioninform', _self.goodsinfo); formData.append('barterCategoryid', _self.goodstype); var _self = this; $.ajax({ type: 'POST', url: 'http://10.145.0.05/goods/addGoods', dataType: "json", data: formData, processData: false, contentType: false, success: function(data) { console.log(data); if (data.code == 200) { console.log("success"); // _self.$router.push('/'); } else { alert(data.message); } } }); }
說明:
類似于formData.append(‘barterCategoryid', _self.goodstype); 是一種鍵值對(duì)的形式保存數(shù)據(jù),而formData.append(“file”, file.files[0], file.files[0].name); 第一個(gè)參數(shù)為服務(wù)端接收的參數(shù)名,第二個(gè)為文件對(duì)象,第三參數(shù)為文件名稱,這樣可以將多個(gè)文件添加為數(shù)組的形式給服務(wù)器。
后端接收該類型的文件時(shí)類型指定為:MultipartFile類型
特別說明:
processData: false,
contentType: false,
這兩句一定要加上,否則數(shù)據(jù)會(huì)被序列化,而導(dǎo)致后端不能識(shí)別
以上是“基于Ajax中formData圖片和數(shù)據(jù)上傳的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!