vue 文件转换二进制_Vue 文件上传后的diy操作及二进制流blob文件的下载[通俗易懂]

vue 文件转换二进制_Vue 文件上传后的diy操作及二进制流blob文件的下载[通俗易懂]文件上传部分1.文件的上传常规的文件上传是通过form表单包裹file类型的input标签进行上传,在form里面的属性中定义上传方式如post,上传地址url,或者通过如elementUI的upload模块进行一系列的上传操作.但很多时候我们并不需要用到那么多复杂功能,所以文件上传的本质应该只有两步:(1)将本地文件上传到浏览器端(2)将浏览器端的文件发送到对应api接口其他的额外操作可以由自己…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

文件上传部分

1.文件的上传

常规的文件上传是通过form表单包裹file类型的input标签进行上传,在form里面的属性中定义上传方式如post,上传地址url,或者通过如elementUI的upload模块进行一系列的上传操作.但很多时候我们并不需要用到那么多复杂功能,所以文件上传的本质应该只有两步:

(1)将本地文件上传到浏览器端

(2)将浏览器端的文件发送到对应api接口

其他的额外操作可以由自己定义.

2.具体代码

上传代码如下:

上传图片

@change=”getimg”

accept=”image/x-png, image/gif, image/jpeg, image/bmp”

class=”fileupload”

ref=”fileupload”

type=”file”

/>

upload() {

this.$refs.fileupload.dispatchEvent(new MouseEvent(‘click’))

},

file类型的input样式很丑而且很不好修改,一般的话对于其的样式优化是将input标签设置为display:none,用我们自定义的按钮或其他来绑定input的点击事件以完成上传的diy风格.

然后是获取上传文件在浏览器的地址:

getimg() {

let file = this.$refs.fileupload.files[0]

this.filename = file.name

let reader = new FileReader() //读取文件

reader.readAsDataURL(file)

let _this = this

reader.onload = function() {

_this.$refs.imgshow.src = reader.result

}

}

一般只有图片需要用到该功能来预览

发送api部分:

addWatermark() {

this.fullscreenLoading = true

let file = this.$refs.fileupload.files[0]

let param = new FormData()

// 将得到的文件流添加到FormData对象

param.append(‘file’, file, file.name)

this.$api.search.addWatermark(param).then()

}

文件上传之后本身并不能直接和一般的数据格式发过去,所以要放在formdata类里面才能达到和包裹在form里面传输一样的效果

注:传输文件是request里面的Content-Type属性一定要是: multipart/form-data

blob下载

很多时候我们从后端接口api拿到的文件类型往往是二进制流的文件,对于这个文件我们前端无法直接下载,所以要通过几步操作

1.请求接口是要告诉接口我请求的是blob类型:responseType: ‘blob’

如axios是这样的axios.post(/addWaterMark, params, { responseType: ‘blob’ });

2.收到请求回调时要对文件blob解析后下载

具体代码是:

if (res.status == 200) {

let blob = new Blob([res.data])

//将二进制流blob数据转化为js认识的blob对象

//有时还要加上类型判别如: let blob = new Blob([res.data], {

// type: ‘application/vnd.ms-excel’

//})

let downloadA = document.createElement(‘a’)

downloadA.download = ‘WM_’ + this.filename

//下载文件命名

downloadA.href = window.URL.createObjectURL(blob)

//获取下载路径

downloadA.click()

}

blob类型汇总

后缀 MIME Type

.doc application/msword

.docx application/vnd.openxmlformats-officedocument.wordprocessingml.document

.xls application/vnd.ms-excel

.xlsx application/vnd.openxmlformats-officedocument.spreadsheetml.sheet

.ppt application/vnd.ms-powerpoint

.pptx application/vnd.openxmlformats-officedocument.presentationml.presentation

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/170653.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • mac全选文字的快捷键_Mac文本快捷键你知道多少?

    mac全选文字的快捷键_Mac文本快捷键你知道多少?我们在MAC电脑上码字的时候,经常会遇到需要对某段文字进行修改或者操作的情况,相信很多人的做法是用鼠标去移动光标快速定位,如果字数篇幅比较小也是可以的,但是如果遇到大篇幅的文章,一点点的用鼠标去找会非常麻烦,今天我就教大家几个MAC文本快捷键,让你在最短的时间内把光标移动到你想要的位置,提高在电脑上码字的效率。image1、全文&段落定位目标位置比较远的时候,需要对光标远程定位,下面的组合…

  • 安卓实现扫码登录_安卓登录界面

    安卓实现扫码登录_安卓登录界面首先不妨先看下Android:扫描二维码登陆原理:大概总结下这个过程就是:服务器生成全局唯一会话ID,并返回二维码、过期时间;用户扫描二维码,提交改会话ID,用户基本信息到服务器;PC端在过期时间内一直轮询,如果用户扫码,服务器记录状态,PC端跳转到已登录页面;那不妨按照这个思路来写一个简单的Demo。1.后台首先,我们需要搭建一个简易版的后台。在IDEA中创建SpringBoot项目,然后添加thymeleaf和session的依赖:<dependency> <

  • vue路由传参的两种方式的区别_vue路由跳转获取参数

    vue路由传参的两种方式的区别_vue路由跳转获取参数vue路由传参的两种方式

  • async/await Task Timeout

    async/await Task Timeout

  • Android物联网应用程序开发(智慧城市)—— 火焰监控界面开发

    Android物联网应用程序开发(智慧城市)—— 火焰监控界面开发效果:布局代码:<?xmlversion=”1.0″encoding=”utf-8″?><RelativeLayoutxmlns:android=”http://schemas.android.com/apk/res/android”xmlns:app=”http://schemas.android.com/apk/res-auto”xmlns:tools=”http://schemas.android.com/tools”androi.

  • 0xc0000225无法进系统_系统重装|电脑无法开机蓝屏错误代码0xc0000225故障问题「建议收藏」

    0xc0000225无法进系统_系统重装|电脑无法开机蓝屏错误代码0xc0000225故障问题「建议收藏」在重装系统的过程中,因为电脑机型,操作等因素,可能会导致重装系统出现一些问题。有的用户重装系统后发现电脑无法开机,显示蓝屏错误代码0xc0000225。为什么会出现这种情况呢?应该如何解决?下面就让小编为大家带来电脑无法开机蓝屏错误代码0xc0000225故障问题。一、原因分析:出现这样的现象是由于系统BCD文件被损坏或者说已经丢失了,通常都是一些用户在UEFI模式下安装GHOST系统导致的。,可…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号