关于fileReader的一个坑

本文介绍了如何使用FileReader API将图片文件转换为Base64格式进行展示,并探讨了JavaScript异步处理机制,解释了为何两次加载相同文件时不会触发加载完成事件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在用fileReader做图片浏览时,
使用base64格式

var file=this.$refs.resource.files[0]
var reader = new FileReader();
// 以DataURL的形式读取文件:
reader.readAsDataURL(file);
//读取后的回调js是多线程
reader.onloadend=(e)=>{

 }
Javascript 本身是单线程的,并没有异步的特性。由于 Javascript 的运用场景是浏览器,浏览器本身是典型的 GUI 工作线程,GUI 工作线程在绝大多数系统中都实现为事件处理,避免阻塞交互,因此产生了 Javascript 异步基因。此后种种都源于此。
//没错,网络,文件。。。。都是基于浏览器的接口实现的
作者:响马
链接:https://www.zhihu.com/question/20866267/answer/25935927
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

如果两次读取的都 是相同的文件,并不会执行加载完成事件。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值