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路由history模式解决404问题的几种方法

    Vue路由history模式解决404问题的几种方法

    这篇文章主要介绍了Vue路由history模式解决404问题的几种方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • Vue前端实现截图功能的简单步骤

    Vue前端实现截图功能的简单步骤

    本文介绍了如何使用html2canvas库来实现HTML页面或某个元素的截图功能,文中通过代码介绍的非常详细,需要注意的是此方法只能在浏览器环境中使用,需要的朋友可以参考下
    2024-10-10
  • vue项目使用electron进行打包操作的全过程

    vue项目使用electron进行打包操作的全过程

    我们都知道Electron项目分为了主进程和渲染进程,主进程其实就是我们的Electron,渲染进程就相当于我们的Vue项目,下面这篇文章主要给大家介绍了关于vue项目使用electron进行打包操作的全过程,需要的朋友可以参考下
    2023-03-03
  • vue-router之路由钩子函数应用小结

    vue-router之路由钩子函数应用小结

    vue-router提供的导航钩子主要用来拦截导航,让它完成跳转或取消,本文主要介绍了vue-router之路由钩子函数应用小结,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01
  • vue开发table数据合并实现详解

    vue开发table数据合并实现详解

    这篇文章主要为大家介绍了vue开发table数据合并实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • vue.js实现的幻灯片功能示例

    vue.js实现的幻灯片功能示例

    这篇文章主要介绍了vue.js实现的幻灯片功能,结合实例形式分析了vue.js实现幻灯片的相关样式、配置、功能等操作技巧,需要的朋友可以参考下
    2019-01-01
  • Vue3集成sass的详细过程

    Vue3集成sass的详细过程

    这篇文章主要介绍了Vue3集成sass的详细过程,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2025-04-04
  • 如何本地运行vue dist文件

    如何本地运行vue dist文件

    这篇文章主要介绍了如何本地运行vue dist文件,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • Vue事件总线的使用问题及解读

    Vue事件总线的使用问题及解读

    这篇文章主要介绍了Vue事件总线的使用问题及解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-03-03
  • 手把手教学vue的路由权限问题

    手把手教学vue的路由权限问题

    这篇文章主要介绍了手把手教学vue的路由权限问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12

最新评论