vue前端如何将任意文件转为base64传给后端

 更新时间:2024年03月07日 10:17:35   作者:相与还  
这篇文章主要介绍了vue前端如何将任意文件转为base64传给后端问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

最近新项目,需要获取文件的bae64编码文本,但是原本是用的vantUI的uploader,对安卓手机的图片上传和文件上传的数量有限制,一次只能上传一张图片(简直麻了),于是舍弃了它,转而图片的继续沿用之前用过的weixin-js-sdk这个微信的上传图片接口进行上传图片。

但是还有一个要求是需要处理pdf为base64,这个微信的只能处理图片,所以花了很长的时间一直在查找资料,终于功夫不负有心人,做出来了获取pdf的base64编码的前端代码。

同时,经过测试,发现这个代码不仅仅能用在pdf上,任意格式,比如pdf,xslx,doc文件都可以转base64。

使用原生input

这个方式,使用的是H5原生的input进行上传文件

// getBase64为获取base64的方法
        <input type="file" @change="getBase64">

具体实现

ps:发现一个问题:reader.onload 获取不到内部的值,查询资料现对如下代码进行修改

原版: 

// 界面
<template>
	<div>
		<input type="file" @change="getBase64">
	</div>
</template>
//js代码
<script>
	export default {
		methods: {
			getBase64(e) {
			// 选择的文件
			let file = e.target.files[0];
			console.log(file.name) // 文件名称,有需求可处理
			console.log(file.type) // 文件类型,有需求可处理
				// 判断文件是否读取完毕,读取完毕后执行
			    if (window.FileReader) {
                    let reader = new FileReader();
                    reader.readAsDataURL(file);
                    reader.onload = function(e) {
                        let base64String = e.target.result;
                        // 此处可对该base64进行获取赋值传入后端
                        console.log("bese64编码:", base64String);
                    }
                }
			}
		}
	}
</script>

修改后:

// 界面
<template>
	<div>
		<input type="file" @change="getBase64">
	</div>
</template>
//js代码
<script>
	export default {
		methods: {
			getBase64(e) {
			// 选择的文件
			let file = e.target.files[0];
			console.log(file.name) // 文件名称,有需求可处理
			console.log(file.type) // 文件类型,有需求可处理
				// 判断文件是否读取完毕,读取完毕后执行
			    if (window.FileReader) {
                    let reader = new FileReader();
                    reader.readAsDataURL(file);
                    reader.onload = e => {
                        let base64String = e.target.result;
                        // 此处可对该base64进行获取赋值传入后端
                        console.log("bese64编码:", base64String);
                    }
                }
			}
		}
	}
</script>

即:

reader.onload = function(e) {}     ======>修改为:
reader.onload = e => {}

主要原因是说function() {} 的方式不支持this,导致获取不到值 

截图

以下为转base64后的截图样例

总结

综上,前端任意文件转base64的代码处理完成!

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

相关文章

  • Vue.js学习教程之列表渲染详解

    Vue.js学习教程之列表渲染详解

    这篇文章主要给大家介绍了关于Vue.js列表渲染的相关资料,文中介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-05-05
  • 解决vue-quill-editor上传内容由于图片是base64的导致字符太长的问题

    解决vue-quill-editor上传内容由于图片是base64的导致字符太长的问题

    vue-quill-editor默认插入图片是直接将图片转为base64再放入内容中,如果图片较多,篇幅太长,就会比较烦恼,接下来通过本文给大家介绍vue-quill-editor上传内容由于图片是base64的导致字符太长的问题及解决方法,需要的朋友可以参考下
    2018-08-08
  • vue3脚手架简单静态路由解读

    vue3脚手架简单静态路由解读

    这篇文章主要介绍了vue3脚手架简单静态路由,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • 一文搞懂VueJs中customRef函数使用

    一文搞懂VueJs中customRef函数使用

    这篇文章主要为大家介绍了VueJs中customRef函数使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • 详解Vue.directive 自定义指令

    详解Vue.directive 自定义指令

    这篇文章主要介绍了Vue.directive 自定义指令,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • 关于vue路由监听事件跳转的问题

    关于vue路由监听事件跳转的问题

    这篇文章主要介绍了关于vue路由监听事件跳转的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • npm install卡在“sill idealTree buildDeps“问题的两种解决方法

    npm install卡在“sill idealTree buildDeps“问题的两种解

    本文主要介绍了npm install卡在“sill idealTree buildDeps“问题的两种解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-03-03
  • 前端通过vue调用后端接口导出excel表格基本步骤

    前端通过vue调用后端接口导出excel表格基本步骤

    在Vue前端项目中,可通过axios库发送请求至后端获取Excel下载链接,文中通过代码介绍的非常详细,对大家的学习或者工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-10-10
  • vue项目中使用rem,在入口文件添加内容操作

    vue项目中使用rem,在入口文件添加内容操作

    这篇文章主要介绍了vue项目中使用rem,在入口文件添加内容操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • 详解vuex中的this.$store.dispatch方法

    详解vuex中的this.$store.dispatch方法

    这篇文章主要介绍了vuex中的this.$store.dispatch方法,必须要用commit(‘SET_TOKEN’, tokenV)调用mutations里的方法,才能在store存储成功,需要的朋友可以参考下
    2022-11-11

最新评论