一次Web端大量图片同时加载卡顿问题的优化之旅

栏目: Html · 发布时间: 5年前

内容简介:由于业务的需要,笔者最近需要实现一个大量图片同时加载的需求。在实现这个需求的过程中,笔者遇到了很多的坑,也总结了一些优化方案。这里将笔者使用或准备使用的优化方案总结一下。在描述如何解决问题,我们现在先来申明,由于不是纯前端的项目,笔者可以从本地文件夹中读取文件。然后一段代码劈里啪啦的就出现了。

由于业务的需要,笔者最近需要实现一个大量图片同时加载的需求。在实现这个需求的过程中,笔者遇到了很多的坑,也总结了一些优化方案。这里将笔者使用或准备使用的优化方案总结一下。

具体场景

在描述如何解决问题,我们现在先来申明, 问题是什么? 笔者的需求大概是在某个页面显示 1~1000张200~500k 大小的图。好消息是这些图片来源于本地硬盘而非网络。(否则这个问题就要变成优化网络....)

踩坑历程

由于不是纯前端的项目,笔者可以从本地文件夹中读取文件。然后一段代码劈里啪啦的就出现了。

const fileList = this.props.fileList;
    return (
        <div className="list-wrapper">
            {
                fileList.map((file) => {
                    <img className="img-item" src={file.src}>
                })
            }
        <div>
    )
复制代码

就在笔者满心欢喜的认为这个需求基本搞定了,该去楼下加鸡腿的时候。无情的现实狠狠的抽了我一巴掌。随着网页的刷新,一张纯白的画面展示在了我的面前,然后只见图片 一点一点的从上面加载出来。 我不禁陷入了沉思,是CPU跑不动道了还是内存飘了?在一想,我这电脑都这个表现,真要上线了,这客户能忍受吗?不对,就这表现,没上线前产品小姐姐就的把我ko了...

方案一 懒加载

这种场景下想必大家第一反应也是懒加载。 简单介绍一下图片懒加载。常见的图片懒加载方案是指页面加载时指渲染屏幕可见区域内周围的图片。当页面滚动时在加载需要显示的图片。

出于提高效(tou)率(lan)的目的,笔者在网上找了个比较好用的懒加载库然后引入项目。 然而,情况并不乐观。因为该需求场景下每一张图片的宽高都是 50*50 ,那么在PC端常见的 1080p 的设备上首屏需要显示的图片达到了 400+张

即便我们忽视这个问题,当用户滚动网页速度很快时图片加载的体验也是不ok的。所以懒加载并不是万能的。

方案二 预加载

首先我们要知道,在硬件性能不变且CPU调度不能更积极的前提下。理论上我们无法减少图片渲染的时间。所以我们只能想办法调整图片渲染的方式来提高用户的体验。 所以我们采用预加在的方式。

const fileList = this.props.fileList;
    fileList.forEach((element) => {
        let img = new Image();
        img.src = element.src;
        img.onload = () => {
            // 渲染这张图
            ...
        }
    })
复制代码

当然我们也可以使用img.decode()方法对图片进行解码,它会返回一个promise对象。

img.decode().then(() => {
    // 渲染这张图
     ...
})
复制代码

采用了这套方案后,图片会一张又一张的加载。然而,加载的速度实在是不敢恭维。如果用户 想看最后那张图片 ,那他只能在哪里进行长久的等待...

方案三 懒加载 + 预加载

众所周知, 3 = 1 + 2。 所以方案三就是方案一和方案二的结合体。 首先我们加载一张图片未加载时的底图(占位)。而后我们继续采用方案二的方式进行图片逐个的预加载。 当用户滚动图片时,我们便改变下一站预渲染的图片为用户可见区域的第一张。 然而,情况还是不乐 懒加载 + 预加载 观。当用户的滚动条匀速直线不停的往下运动时,效果依然很差。

终结方案

综合上面集中方案,基本能优化的我们都已经优化。那如继续何提高用户的体验呢?似乎,我们只能从图片本身去下手?

上文也提到,在我所面临的需求场景下一张图片的显示宽高为 50 * 50 。 而图片的大小为 200~500k 大小的图。所以我们可以采用缩率图的方式,渲染一张3~5k大小的图片。 采用缩略图的情况下我们在使用方案三进行优化几乎就可以满足这个场景下用户的需求了。

其他

当然,上面的只是我在某个项目中使用的某些方案。我们仍然可以采用例如图片渐进式增强,CDN缓存,图片压缩,设立单独的资源服务器等诸多方式。图片的加载优化本身也时一个前端老生常谈的问题,业内已经有太多太多的解决方案。如果你有更好的方案,你也可以在下面留言告诉我。谢谢观看。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Effective Ruby:改善Ruby程序的48条建议

Effective Ruby:改善Ruby程序的48条建议

Peter J. Jones / 杨政权、秦五一、孟樊超 / 机械工业出版社 / 2016-1 / 49

如果你是经验丰富的Rub程序员,本书能帮助你发挥Ruby的全部力量来编写更稳健、高效、可维护和易执行的代码。Peter J.Jones凭借其近十年的Ruby开发经验,总结出48条Ruby的最佳实践、专家建议和捷径,并辅以可执行的代码实例。 Jones在Ruby开发的每个主要领域都给出了实用的建议,从模块、内存到元编程。他对鲜为人知的Ruby方言、怪癖、误区和强力影响代码行为与性能的复杂性的揭......一起来看看 《Effective Ruby:改善Ruby程序的48条建议》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具