JavaScript原生将图片转成base64

1.写个html文件

html 复制代码
<!-- 产品照片 -->
<div class="mb-3">
<label for="cover" class="form-label">产品图片</label>
    <input
        type="file"
        class="form-control"
        id="coverfile"
    />
</div>

2.写个js文件

说明:

FileReader对象允许 Web 应用程序异步读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,使用 File对象指定要读取的文件或数据。

javascript 复制代码
// 产品图片
let cover = "";
//获取coverfile节点
const coverfile=document.querySelector("#coverfile")

coverfile.onchange = function (e) {
  // 创建一个 FileReader 对象,用于读取文件内容。
  let reader = new FileReader();
  //   base64读取
  // 使用 readAsDataURL 方法读取用户选择的文件。e.target.files[0] 表示用户选择的第一个文件。
  reader.readAsDataURL(e.target.files[0]);
  //   加载完成
  // 当文件加载完成后,onload 事件会被触发,执行相应的回调函数。
  reader.onload = function (event) {
    // 表示读取到的所有文件内容,即文件的 base64 编码。
    cover = event.target.result;
  };
};
};

3.效果展示

相关推荐
电商API&Tina3 分钟前
跨境电商高并发 API 接口接入指南(技术落地 + 高可用优化)
大数据·服务器·前端·数据库·python·json
duanyuehuan5 分钟前
vue 项目中.d.ts
前端·javascript·vue.js
阿珊和她的猫7 分钟前
Webpack 动态引入的实现原理与应用
前端·webpack·node.js
小粉粉hhh8 分钟前
记录前端菜鸟的日常——Pdf.js与双指缩放
前端·javascript·pdf
ok06012 分钟前
Chrome 小工具: 启动本地应用 (Native messaging)
前端·chrome
求梦82014 分钟前
前端基础三剑客
前端
pas13619 分钟前
27-mini-vue provide-inject
前端·javascript·vue.js
_UMR_19 分钟前
前端Vue开发环境搭建(安装Node.js)
前端·vue.js·node.js
天空属于哈夫克322 分钟前
企业微信实现外部群消息的主动推送?
前端·chrome·企业微信
咬人喵喵22 分钟前
16 类春节核心 SVG 交互方案拆解(E2 编辑器实战)
前端·css·编辑器·交互·svg