首页 > 其他分享 >vue如何实现文件上传及预览

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

时间:2023-12-11 09:56:23浏览次数:26  
标签:文件 vue console log 预览 file reader 上传

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)         })       }     }

总结

以上为个人经验,希望能给大家一个参考

 

参考文章:http://blog.ncmem.com/wordpress/2023/12/11/vue%e5%a6%82%e4%bd%95%e5%ae%9e%e7%8e%b0%e6%96%87%e4%bb%b6%e4%b8%8a%e4%bc%a0%e5%8f%8a%e9%a2%84%e8%a7%88/

欢迎入群一起讨论

 

 

标签:文件,vue,console,log,预览,file,reader,上传
From: https://www.cnblogs.com/songsu/p/17893725.html

相关文章

  • NodeJS项目build成为本地镜像上传阿里云ACR
    先注册阿里云账号选择“容器镜像服务”->“个人实例”。由于是测试目的,个人版也可以接受。创建命名空间创建镜像仓库选择本地仓库-本示例会从本机推送镜像创建成功后,会有提示相关命令创建一个nodejs项目package.json{"name":"docker_web_app","versio......
  • vue3中自定义ref实现防抖
    import{customRef}from"vue";/***@description自定义ref实现防抖*@param{String}value*@param{Number}delay*@returns*/exportconstdebounceRef=(value,delay)=>{lettimer;returncustomRef((track,trigger)=>({......
  • 如何在微信公众号上传附件
    微附件是一个为微信公众号提供文件管理服务的便捷工具。它允许运营者轻松上传和管理各式文档,涵盖Word、Excel、PPT、PDF和TXT格式。通过微附件,用户能够便捷地下载这些文件。该工具特别适合于公众号分享各种文档,如职位空缺、申请表格、注册资料、报名表、比赛公告、公示列表、招标信......
  • VUE框架CLI组件化全局事件总线实现原理------VUE框架
    <template> <div> <!--内置函数的实现步骤--> <!--提供事件源,给事件源绑定事件,编写回调函数,将回调函数和事件进行绑定--> <!--等待事件的触发,事件触发执行回调函数--> <!--组件的自定义事件实现步骤--> <button@click="Hello()">你好</button> <!--给Us......
  • [Vue]脚手架创建项目
    文档:https://cli.vuejs.org/zh/(脚手架最新版本是4.x) 1.如果安装速度过慢,可以指到国内安装地址:npmconfigsetregistryhttps://registry.npm.taobao.org2.首次安装(全局):npminstall-g@vue/cli 3.切换到创建项目的目录,使用命令创建项目 vuecreatexxx4.选择使用......
  • Vue 3 使用moment设置显示时间格式
    一.问题:Vue3如何使用moment设置显示时间格式。二.分析问题:在Vue3中,因为过滤器(filter)已经被废弃,取而代之的是全局方法(globalmethod)。slot-scope也被弃用使用v-slot代替。无法使用过滤器设置显示时间格式。三. 解决问题。  (1)在vueui安装moment依赖,搜索安装即可。......
  • vue3学习之createApp(App).mount('#app')
    装了vue-cli之后,新建个项目跑起来了,碰上个没理解的问题,不知道createApp(App).mount('#app')挂载的这个id=“app”从哪冒出来的 用命令创建出来的项目,components/HelloWorld.vue,App.vue,main.js中都没有估摸着得是底层的,网上找一圈,各路大神基本是一句带过,可能是太简单了,没......
  • 使用Vue和Element UI进行文件上传的简单教程
    当使用Vue和ElementUI进行文件上传时,你可以按照以下步骤进行操作:步骤1:安装Vue和ElementUI在你的Vue项目中使用npm或者yarn安装Vue和ElementUI:npminstallvueelement-ui步骤2:创建上传组件创建一个Vue组件来处理文件上传的逻辑。在组件的<template>中添加一个文件上传的按钮和......
  • 【前端框架Vue】Vue是什么?怎么用?
    Vue是JS的一种框架,用于构建用户界面的JS框架。可以理解为,Vue通过指令和模板语法,将数据和HTML模板关联起来,实现一种响应式的数据驱动视图的方式Vue是什么?Vue是JS的一种框架,用于构建用户界面的JS框架。可以理解为,Vue通过指令和模板语法,将数据和HTML模板关联起来,实现一种响应式的......
  • Vue源码学习(十八):实现组件注册(一)Vue.component()和Vue.extend()
    好家伙, 0.完整代码已开源https://github.com/Fattiger4399/analytic-vue.git 1.思路1.1.什么是组件化? Vue组件化是指将复杂的应用程序拆分成多个独立的、可复用的组件,这些组件可以实现特定的功能或局部功能。组件化有助于提高开发效率、方便重复使用、简化调试步骤......