vue如何实现文件上传及预览

 更新时间:2023年06月08日 15:02:14   作者:秦璐璐  
这篇文章主要介绍了vue如何实现文件上传及预览问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

vue文件上传及预览

<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对象
reader.readAsDataURL(file); //读取为base64
//以下代码可以删除
reader.onloadstart = function() {
console.log("start"); //开始读取
};
//代码进度条
reader.onprogress = function(e) {
//这个是定时触发的事件,文件较大的时候较明显
//console.log(e)
var p = "已完成:" + Math.round(e.loaded / e.total * 100) + "%";
$(".file_upload")
.find(".progress")
.html(p);
console.log("uploading"); //文件较大,就会出现多个uploading
};
reader.onabort = function() {
console.log("abort"); //用作取消上传功能
};
reader.onerror = function() {
console.log("error"); //文件读取出错的时候触发,暂模拟不出
};
//成功后 获取文件url
reader.onload = function(e) {
console.log("load complete"); //完成
console.log(e);
let res = e.target.result.split(";"); //截取 data:; base64 转换后默认会有data属性判断文件格式;分为两段,前段为data,后端为文件base64编码
if (res[0] != "data:application/apk;") {
// 不同浏览器会有不一样的解析;so 这一步单独处理
_this.apk.app = "data:application/apk;" + res[1];
} else {
_this.apk.app = e.target.result;
}
console.log(_this.apk.app)
};
//预览代码
reader.onloadend = function(e) {
var dataURL = reader.result,
image = '<img src="' + dataURL + '"/>', //预览图片
text = '<span>"' + dataURL + '"</span>'; //测试预览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("请选择我们支持的图片格式!");
// return false;
// }
// if (size > 3145728) {
// alert("请选择3M以内的图片!");
// return false;
// }
}
}
};
</script>
 

vue多文件上传并预览

多文件上传预览基本思路

1、获取所上传的文件,input发生change事件时获取 e.target.files,这个变量就是文件列表

2、文件上传用的时FormData格式,这里我循环遍历了文件列表,并把文件append到FormData对象里

3、提交时把FormData对象提交到服务器即可

4、预览功能我用的FileReader的readAsDataURL方法将上传图片转为base64

5、读取操作是异步读取,这里用了Promise,读取操作完成后,触发onload事件,返回一个resolve状态并带上base64编码的字符串

6、将base64这串字符赋给img元素的src,即可预览图片

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) {
      // 获取预览图片的base64
        return new Promise((resolve, reject) => {
          let read = new FileReader()
          read.readAsDataURL(file)
          read.onload = function(e) {
            resolve(this.result)
          }
        })
      },
      upload (e) {
      // 选择图片后触发,将文件放到 formdata 对象里
        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将数据发送到服务器
        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)
        })
      }
    }

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。 

相关文章

  • vue3 elementPlus 表格实现行列拖拽及列检索功能(完整代码)

    vue3 elementPlus 表格实现行列拖拽及列检索功能(完整代码)

    本文通过实例代码给大家介绍vue3 elementPlus 表格实现行列拖拽及列检索功能,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-10-10
  • Vue nextTick延迟回调获取更新后DOM机制详解

    Vue nextTick延迟回调获取更新后DOM机制详解

    这篇文章主要为大家介绍了Vue nextTick延迟回调获取更新后DOM机制详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • axios+vue请求时携带cookie的方法实例

    axios+vue请求时携带cookie的方法实例

    做项目时遇到一个需求,后端需要在接口请求时,对用户登陆状态进行判断,需要在请求时携带Cookie,下面这篇文章主要给大家介绍了关于axios+vue请求时携带cookie的相关资料,需要的朋友可以参考下
    2022-09-09
  • Vue3中#default=“scope”的使用

    Vue3中#default=“scope”的使用

    在Vue3中,我们经常会遇到需要处理列表渲染的情况,Vue3引入了一种新的语法,即#default=“scope”,本文就来介绍一下Vue3中#default=“scope”的使用,感兴趣的可以了解一下
    2023-10-10
  • Vue声明式导航与编程式导航示例分析讲解

    Vue声明式导航与编程式导航示例分析讲解

    这篇文章主要介绍了Vue中声明式导航与编程式导航,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2022-11-11
  • 在Vuex中Mutations修改状态操作

    在Vuex中Mutations修改状态操作

    这篇文章主要介绍了在Vuex中Mutations修改状态操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • Vue中组件命名与引用过程

    Vue中组件命名与引用过程

    Vue组件命名在引入和引用时因大小写转换规则差异,PascalCase用于JS定义,kebab-case用于模板,Vue会自动映射,推荐统一使用短横线命名,单文件组件(SFC)整合模板、脚本和样式,结构清晰,是Vue项目的核心组织方式
    2025-07-07
  • 前端elementUI select选择器实现远程搜索

    前端elementUI select选择器实现远程搜索

    这篇文章主要为大家介绍了前端使用elementUI select选择器实现远程搜索,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • vue如何实现拖动图片进行排序Vue.Draggable

    vue如何实现拖动图片进行排序Vue.Draggable

    这篇文章主要介绍了vue如何实现拖动图片进行排序Vue.Draggable,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • Vue中的Props(不可变状态)

    Vue中的Props(不可变状态)

    这篇文章主要介绍了Vue中的Props(不可变状态),本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-09-09

最新评论