从零开始学_JavaScript_系列(36)——base64字符串与图片的相互转换

base64字符串转图片

原理是当base64字符串作为img标签的src属性时,如果是有效的,则可以预览。

而若要下载,则

  1. 创建一个新的a标签
  2. 将a标签的href属性设置为该base64字符串
  3. 设置a标签的download属性为文件名

再通过js手动触发该a标签的点击事件,则完成了下载行为(具体视浏览器可能需要选择下载目录或者使用默认目录)。

图片转base64字符串

分为两种,一种是提供图片的src标签,另一种是通过上传图片文件。

提供图片的src标签

需要借助canvas标签来完成。

优点是……可以缩放图片大小?

缺点是不能跨域(但另外一个也不行)

顺序如下:
1. 用户提供src
2. 创建新的img标签,并将src设置给img标签
3. img标签加载完毕(onload回调触发),继续执行以下代码:
4. 将该图片写入canvas(此时可以根据图片大小设置该canvas的大小,或者让图片自适应canvas的大小)
5. 通过canvas的toDataURL方法获取base64字符串
6. 输出该base64字符串;

文件上传形式

需要input标签支持type=file,需要使用FileReader对象

优点是选完文件后自动转换,操作更简单一些。

顺序如下:

  1. 当type=file的input标签触发onchange事件时,开始执行以下指令
  2. 创建一个新的FileReader对象;
  3. 使用其的readAsDataURL这个API,读取文件内容;
  4. 当读取成功时(触发onload回调函数),可以通过回调函数的参数e,利用属性e.target.result获取base64字符串;
  5. 该base64字符串即为所需要的内容。

DEMO页面:

图片转为base64字符串

base64字符串转为图片

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值