大图片加载优化解决方案

原创文章 作者:月光光 2016年04月03日 13:06helloweba.com 标签:HTML5 

我们浏览页面上加载有大尺寸图片时,由于图片体积也比较大,我们会看到浏览器加载图片的时候会从上到下逐步显示图片,直到图片完整呈现在页面上,这样图片从空白区域到完全加载的过程显得比较突兀,用户体验比较差。

大图片加载优化解决方案

我们使用的解决办法是先加载一张很小的缩略图,它可能只有1K左右,并且按所需尺寸模糊显示,等到大尺寸图片下载好再完整显示大图。这样给用户的感觉是先加载模糊的图片,然后再是变清晰的图片,图片加载过程流畅,极大的提高用户体验。

HTML

我们准备一张大图,当然它尽可能的大,可能几百KB,甚至上MB。我们同时还制作一张缩略图,非常小,可能就1kb左右,我们可以将这张缩略图转换成Base64的图片,如下代码中,将data-antimoderate-idata属性值定义为base64图片。

<img src="images/a.jpg" id="pic" style="width:800px; height:576px;" data-antimoderate-idata="">

Javascript

在不做js处理时,我们还是会看到一张慢慢从上到下加载的大图。非常幸运的是,antimoderate.js帮我们处理加载的问题,看如何使用它。

<script src="antimoderate.js"></script>
<script>
    var img = document.getElementById('pic');

    AntiModerate.process(img, img.getAttribute("data-antimoderate-idata"));
</script>

Antimoderate.js使用了html5的canvans将图片做了处理,优先加载缩略图,并做模糊化,当大图下载完成时加载大图显示,使用它极大的加快了网页打开速度。

声明:本文为原创文章,helloweba.net和作者拥有版权,如需转载,请注明来源于helloweba.net并保留原文链接:https://www.helloweba.net/javascript/358.html

8条评论

  • 大规模图片应用用这个应该就不可以了吧 比我批量从数据库调用图片地址 总不能预先做个图片转换吧

  • 挺好

  • 这个不好,data-antimoderate-idata的数据是不能被缓存304状态的,假如你的页面很多图,单单是读取这个页面的html文件就要好多带宽开销。

  • 好思路

  • 有懒加载、预加载等方式。。

  • 这个酷啊~!对用户体验忒好了...像某宝的加载方式 叫什么

  • 百度下“base64 图片转换” 有在线转换工具可以用,或者使用PHP等后台程序生成。

  • 不失用户体验和seo的好方法,但请问怎么将缩略图转换成Base64的图片?