资讯专栏INFORMATION COLUMN

web图片上传时的一种本地压缩预览方案

ytwman / 1313人阅读

摘要:简介本文结合实际项目场景,记录图片上传时的一种本地压缩预览解决方案。考虑到这些问题,决定采用本地图片进行预览。解决过程接下来说明将待上传的本地图片展示到界面中。这样就在前端实现了简单的图片压缩处理。

简介

本文结合实际项目场景,记录图片上传时的一种本地压缩预览解决方案。这里的本地预览是指,页面上的图片是读取的本机资源进行展示,而没有通过网络请求加载。

实际的项目场景

在这阵子的项目开发中需要上传图片。需求很简单,能上传图片,并按如下UI效果展示即可。

图1 上传完成后的效果

开发时,我首先是对新选择图片的上传进度进行了加载展示,等到单个图片上传完成,调取相应api拿到图片的存储url,然后根据url加载图片展示在界面。像这样:

图2. 原始的uploading UI

不足之处

以上是原始开发方案,弄完之后,我发现这样有两个比较大的问题:

图片需要等到上传结束,并拿到下载url才能展示在界面,而上传过程中,则看不到图片的样子(如上图2). 这样用户只能在上传完成后才能检查是否选择正确。

图片上传完后,需要加载url以显示图片,相当于上传后又从存储服务器下载了一遍。这不仅占用网络资源,而且会导致「上传完毕到图片展示出来 两者之间的卡顿」,因为加载图片需要时间。

考虑到这些问题,决定采用本地图片进行预览。 这样上面两个问题都能解决——上传过程中能预览图片、上传完成后不需再从服务器加载 。

解决过程

接下来说明将待上传的本地图片展示到界面中。

这里我使用的是HTML5的FileReader对象来读取选中的图片数据,FileReader对象提供的API中有一个是「readAsDataURL」,顾名思义,就是读取文件内容并处理成一种特殊的URL地址,该URL地址能直接加载到页面中, 比如赋值给img元素的src属性。

现在假设已经获取到了图片的file source——比如从中的files,然后通过如下简单的几行代码就能读取文件:

export const readFile = (file)=>{
    return new Promise((resolve)=>{
        let reader = new FileReader();
        reader.readAsDataURL(file);
        reader.onload = function(){ 
             //读取完会触发unload事件,  同时result属性就是需要的结果,它的格式为「data:URL」
             // do something with this.result  
             // e.g: resolve(this.result)   
             //...
        });
    };
});

};

将上诉结果作为图片加载到上传页面中,这样,在上传之前,就能先读取图片并展示到页面中了。uploading UI 变成了这样子:

图3: 改进之后的uploading UI

继续改进 – 图片压缩

至此似乎已经解决问题了,但考虑到该业务场景下,图片都是以小图展示的,所以又想着可以把图片压缩一下再预览,毕竟FileReader的readAsDataURL方法是直接以base64对图片进行编码的,不压缩的话吃内存较多。

压缩是借助canvas画布技术来做的。大体步骤就是将上传的大图画到一张小的画布上,然后将新绘制的小画布导出成data URL作为输入结果。这样就在前端实现了简单的图片压缩处理。

备注

该方案尚存诸多不足之处,比如最起码的FileReader兼容性问题,在IE10以下版本就不支持。网上对IE旧版本建议用「滤镜」来兼容。 欢迎讨论。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/80458.html

相关文章

  • 前端文件上传(js/vue.js/axios/canvas图片压缩)

    摘要:哈哈主要还是我嫌麻烦四上传图片这里的页面样式,图片压缩和预览都和上面一样,这里我主要配置一下的,让接口能够成功上传。如果想让用户有更好的体验,可以对图片进行一下压缩和本地预览。 一、通过Form表单提交上传 HTML enctype属性必不可少 上面一种方法通过表单自有属性进行提交,看似简单,但是也有其最大的缺点,那就是提交...

    Luosunce 评论0 收藏0
  • 前端文件上传(js/vue.js/axios/canvas图片压缩)

    摘要:哈哈主要还是我嫌麻烦四上传图片这里的页面样式,图片压缩和预览都和上面一样,这里我主要配置一下的,让接口能够成功上传。如果想让用户有更好的体验,可以对图片进行一下压缩和本地预览。 一、通过Form表单提交上传 HTML enctype属性必不可少 上面一种方法通过表单自有属性进行提交,看似简单,但是也有其最大的缺点,那就是提交...

    Lsnsh 评论0 收藏0
  • 精彩文章大合集- 收藏集 - 掘金

    摘要:发布应用市场的平台抢红包工具红包精灵开源啦掘金红包精灵,如果喜欢,点个开源不易。作者将原素材文章进行了新内容的添加和重新排列,但是因为文章高效的代码编写技巧总结前端掘金本文总结了代码编写技巧,来提升你的和代码。 收藏安卓开发中非常实用优秀的库! 有图有真相! - Android - 掘金本来是打算收藏工具类的,但转念一想,已经有这么多优秀的库了,就没必要再去重复造轮子了,便归纳工作中比...

    ermaoL 评论0 收藏0
  • 实践是检验程序员的唯一标准01:用户不想跟你说话并向你扔出一张图片 - 图片上传组件开发【思路篇】

    摘要:表示不一定是原生形式的数据。接口基于,继承了的功能并将其扩展使其支持用户系统上的文件。读取操作完成的时候,会变成已完成,并触发事件,同时属性将包含一个格式的字符串编码以表示所读取文件的内容。 温馨提示:这里除了一些幼稚的小组件啥也没有温馨提示-续:这是一个新的系列,写一些实际开发中遇到的一些常用的功能,想法笨拙,代码乱套 写在前面 图片上传,作为web端一个常用的功能,在不同的项目中有...

    PiscesYE 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<