react 中实现图片分批加载优化加载卡顿问题

一、react 中实现图片分批加载优化加载卡顿问题
  1. react 中,当页面图片数量太多时,一次性请求所有的图片,会很卡顿造成用户的体验不好,可以采用分批加载的方式去请求图片进行优化。
  2. 对于优化的实现思路,先将所要渲染 image url 置空。在 loadImages 函数中,needToLoadList 为所有图片的路径,maxLoadedNum 为最大加载数量,curLoadedImgList 为正在加载的图片列表,loadIndex 为当前加载的图片索引,imagedoms 为所要渲染的图片 DOMstartLoadImg 开始加载图片,可以理解为队列的入栈出栈,当正在加载的图片列表小于最大加载数量,入栈,加载完后出栈,后面的图片列表继续入栈,依次递进。若全部加载完毕则整个队列的入栈出栈的流程结束。removeAndReloadImg 是删除图片,开始下一轮加载,代码如下所示:
function loadImages(imageList, maxLoadingNum) {
   
  const needToLoadList = imageList; 
  const maxLoadedNum = maxLoadingNum; 
  const curLoadedImgList: string[] = []; 
  let index = 0; 
  let imagesIdList = []; 
  const imagedoms = document.querySelectorAll
1、这个软件使用C#编写,需要.NET Framework 4.0运行环境。 2、建议“新建文件夹”来保存分割后的图片,因为程序会自动清空该文件夹下所有文件。 3、这个软件可以对图片进行,行与列的分割。如果大家按块对图片进行行分割,那么分割列数填写1,分割行书填写自己要分割的行;如果大家按块数想对列分割,那么分割列数填写要分割的列数,分割行数填写1。如果大家按像素对图片进行横向切割,那么像素宽度填写1,高度随便写;如果按像素对图片进行纵向切割,那么像素高度填写1,像素宽度随便写。 4、分割图片的耗时跟图片大小、切割块数的多少有直接关系。另外,图片在切割的时候无论何种切割方式都是将图片读取到内存中进行切割,所以注意一下自己机器内存的大小,以及图片的大小。以免内存报错。 5、从网上直接加载图片时候,图片类型只能为jpg或者png格式,其他类型的图片暂不支持。另外,在输入时一定要输入“http://”或"https://",输入完毕后按回车键。 6、图片九宫格合并,主要在文件的命名上,文件名以数字开头,类似于“0_0.jpg”这样的文件名,其中第一个0代表行,第二个0代表列,0_0这样的文件名是指第一行,第一张图片,0_1是指第一行,第二张图片,0_2是指第一行,第三张图片以此类推。具体看文章上方关于九宫格的图片说明。 7、由于程序在编译的时候使用了代码保护软件进行保护,所以在运行的时候360之类的软件会有报警,如果大家很在意360之类的报警提示的话。那就绕行吧。。。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值