vue如何實(shí)現(xiàn)文件上傳及預(yù)覽
vue文件上傳及預(yù)覽
<template>
<div id="file">
<input name="files" id="uploaderInput" type="file" accept="images/*" multiple @change="change"/>
<div class="file_upload">
<div class="progress"></div>
</div>
<div class="img_holder"></div>
</div>
</template>
<script>
export default {
name: "file",
methods: {
change(E) {
//獲取到獲取的圖片列表 (選擇多張)
let file = event.target.files[0];
//獲取到獲取的圖片列表 (選擇一張)
//let img1 = event.target.files[0];
//let reader = new FileReader();
//console.log($("#uploaderInput")[0].files);
//console.log(img1);
//let type = file.type; //文件的類型,判斷是否是圖片
//let size = file.size; //文件的大小,判斷圖片的大小
var reader = new FileReader(); //新建FileReader對(duì)象
reader.readAsDataURL(file); //讀取為base64
//以下代碼可以刪除
reader.onloadstart = function() {
console.log("start"); //開始讀取
};
//代碼進(jìn)度條
reader.onprogress = function(e) {
//這個(gè)是定時(shí)觸發(fā)的事件,文件較大的時(shí)候較明顯
//console.log(e)
var p = "已完成:" + Math.round(e.loaded / e.total * 100) + "%";
$(".file_upload")
.find(".progress")
.html(p);
console.log("uploading"); //文件較大,就會(huì)出現(xiàn)多個(gè)uploading
};
reader.onabort = function() {
console.log("abort"); //用作取消上傳功能
};
reader.onerror = function() {
console.log("error"); //文件讀取出錯(cuò)的時(shí)候觸發(fā),暫模擬不出
};
//成功后 獲取文件url
reader.onload = function(e) {
console.log("load complete"); //完成
console.log(e);
let res = e.target.result.split(";"); //截取 data:; base64 轉(zhuǎn)換后默認(rèn)會(huì)有data屬性判斷文件格式;分為兩段,前段為data,后端為文件base64編碼
if (res[0] != "data:application/apk;") {
// 不同瀏覽器會(huì)有不一樣的解析;so 這一步單獨(dú)處理
_this.apk.app = "data:application/apk;" + res[1];
} else {
_this.apk.app = e.target.result;
}
console.log(_this.apk.app)
};
//預(yù)覽代碼
reader.onloadend = function(e) {
var dataURL = reader.result,
image = '<img src="' + dataURL + '"/>', //預(yù)覽圖片
text = '<span>"' + dataURL + '"</span>'; //測(cè)試預(yù)覽text
var name = file.name,
size = Math.round(file.size / 1024);
var div = "<p>Name: " + name + "</p><p>Size: " + size + "kb</p>";
var imglist =
'<div class="img_box"><span class="delete">X</span>' +
image +
div +
"</div>";
$(".img_holder").html(imglist);
};
// if (this.imgData.accept.indexOf(type) == -1) {
// alert("請(qǐng)選擇我們支持的圖片格式!");
// return false;
// }
// if (size > 3145728) {
// alert("請(qǐng)選擇3M以內(nèi)的圖片!");
// return false;
// }
}
}
};
</script>
vue多文件上傳并預(yù)覽
多文件上傳預(yù)覽基本思路
1、獲取所上傳的文件,input發(fā)生change事件時(shí)獲取 e.target.files,這個(gè)變量就是文件列表
2、文件上傳用的時(shí)FormData格式,這里我循環(huán)遍歷了文件列表,并把文件append到FormData對(duì)象里
3、提交時(shí)把FormData對(duì)象提交到服務(wù)器即可
4、預(yù)覽功能我用的FileReader的readAsDataURL方法將上傳圖片轉(zhuǎn)為base64
5、讀取操作是異步讀取,這里用了Promise,讀取操作完成后,觸發(fā)onload事件,返回一個(gè)resolve狀態(tài)并帶上base64編碼的字符串
6、將base64這串字符賦給img元素的src,即可預(yù)覽圖片
template:
<input type="file" multiple @change="upload" /><br /> <img v-for="item in previewUrl" :src="item" width="100" /><br /> <button type="button" @click="submitFile">submitFile</button>
js:
data () {
return {
previewUrl: [],
formData: undefined
},
methods: {
preview (file) {
// 獲取預(yù)覽圖片的base64
return new Promise((resolve, reject) => {
let read = new FileReader()
read.readAsDataURL(file)
read.onload = function(e) {
resolve(this.result)
}
})
},
upload (e) {
// 選擇圖片后觸發(fā),將文件放到 formdata 對(duì)象里
this.previewUrl = []
const files = e.target.files
const that = this
this.formData = new FormData()
console.log(files)
for(let file of files){
this.formData.append('file', file)
this.preview(file).then(res => {
that.previewUrl.push(res)
})
}
console.log(this.formData.getAll('file'))
},
submitFile (file, fileList) {
// axios將數(shù)據(jù)發(fā)送到服務(wù)器
let setting = {
url: 'http://localhost:3000/uploadfile',
method: 'post',
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
},
data: this.formData
}
this._axiosMock(setting).then(res => {
console.log(res)
})
}
}總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
el-form組件清除校驗(yàn)提示正確方法(前端技能提升)
el-form組件提供了表單驗(yàn)證的功能,可以通過在el-form上綁定rules屬性,并在el-form-item上設(shè)置prop屬性來進(jìn)行校驗(yàn),這篇文章主要給大家介紹了關(guān)于el-form組件清除校驗(yàn)提示正確方法(前端技能提升)的相關(guān)資料,需要的朋友可以參考下2023-12-12
Vue3+ts+setup?getCurrentInstance使用時(shí)遇到的問題以及解決辦法
getCurrentInstance方法用于獲取當(dāng)前組件實(shí)例,僅在setup和生命周期中起作用,下面這篇文章主要給大家介紹了關(guān)于Vue3+ts+setup?getCurrentInstance使用時(shí)遇到的問題以及解決辦法,需要的朋友可以參考下2022-08-08
vue父組件觸發(fā)事件改變子組件的值的方法實(shí)例詳解
這篇文章主要介紹了vue父組件觸發(fā)事件改變子組件的值的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05
基于electron+vue3+ts搭建桌面端應(yīng)用并且可以熱更新
這篇文章主要為大家詳細(xì)介紹了如何基于electron+vue3+ts搭建桌面端應(yīng)用并且可以熱更新,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以參考下2023-10-10
vue+element+springboot實(shí)現(xiàn)文件下載進(jìn)度條展現(xiàn)功能示例
本文主要介紹了vue + element-ui + springboot 實(shí)現(xiàn)文件下載進(jìn)度條展現(xiàn)功能,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
vue自定義一個(gè)v-model的實(shí)現(xiàn)代碼
這篇文章主要介紹了vue自定義一個(gè)v-model的實(shí)現(xiàn)代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-06-06
Vue2.X 通過AJAX動(dòng)態(tài)更新數(shù)據(jù)
這篇文章主要介紹了Vue2.X 通過AJAX動(dòng)態(tài)更新數(shù)據(jù)的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-07-07
vue實(shí)現(xiàn)輸入框的模糊查詢的示例代碼(節(jié)流函數(shù)的應(yīng)用場(chǎng)景)
這篇文章主要介紹了vue實(shí)現(xiàn)輸入框的模糊查詢的示例代碼(節(jié)流函數(shù)的應(yīng)用場(chǎng)景),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09

