当前位置: 首页 > news >正文

JavaScript + setInterval实现简易数据轮播效果

项目场景:

根据不同分类数据,实现数据TOP榜轮播。比如,这里有20种类型,满足这20种类型下的TOP详情数据轮播渲染。


问题描述

提示:重点是后端接口无法满足全量分类的TOP排行数据量,这里只能前端根据不同分类逐一请求并渲染

大致思路:
1、轮播肯定需要满足一个时间差,考虑到循环,这里使用定时器const timer = setInterval();
2、记录分类总量const lengthType:number = typeLists.length. (这里typeLists为分类数据集),便于后期请求控制;
3、步骤一暂定一分钟跑一次请求 getTopSellingList();
4、步骤三完成后,保存当前分类TOP详情 let showTOPInfos={},后面解释为什么用对象;
5、if Object.keys(showTOPInfos).length < lengthType. 重复步骤三、四
6、if Object.keys(showTOPInfos).length === lengthType. 结束定时器timer;
7、此时进入重要环节,对已经获取的数据实现切换渲染,定义const allTimer = setInterval(),根据分类每分钟一次渲染一个分类TOP排行数据;


实现部分:

提示:第一个setInterval为了逐一获取分类数据并轮播渲染,第二个setInterval则是获取完整数据后对数据进行后续轮播渲染:

获取数据
// 分类TOP数据查询 typeCode 分类标识
export const getTopSellingList = async (typeCode = '', ) => {
  const promise = await new Promise((resolve, reject) => {
           // 你的数据请求
           if (‘成功’) {
              resolve(best_sale_list);
            } else {
             reject(‘失败’);
            }            
  });
  return promise;
};

这里实现轮播效果:

   
            //  立即执行渲染一次 
            getTopSellingList(typeLists[0]?.typeCode).then((res) => {
              //对应分类top数据  TODO:接口获取
              showTOPInfos[typeLists[0]?.typeName] = res;
              setTopInfos(showTOPInfos, typeLists[0]?.typeName, res)// 渲染top榜数据
            });

            // 一分钟获取一次,并渲染(全部分类获取为止)
            const timer = setInterval(() => {
              const lengthType:number = typeLists.length; // 分类总数
              let lengthTOP = Object.keys(showTOPInfos).length; // 待展示的分类TOP总数
              if (lengthTOP < lengthType) {
                let nowTOP = typeLists[lengthTOP]; // 当前要获取的TOP分类
                getTopSellingList(nowTOP?.typeCode).then((res) => {
                  const newTOPInfos = { [nowTOP?.typeName]: res }; 
                  // 记录追加本次获取的数据
                  showTOPInfos = { ...showTOPInfos, ...newTOPInfos };
                  setTopInfos(showTOPInfos, owTOP?.typeName, res)// 渲染TOP榜数据
                });
              } else if (lengthTOP === lengthType) {
                // 分类TOP总数达上限时 循环渲染分类TOP数据
                let nowIndex = 0; // 记录当前展示TOP分类索引
                allTimer = setInterval(() => {
                  // 循环上限后重置
                  if (nowIndex === Number(typeLists.length)) {
                    nowIndex = 0;
                  }
                  const nowTypeName = typeLists[nowIndex].typeName; // 当前TOP分类名称
                  // 渲染标题
                   setTopInfos(showTOPInfos, nowTypeName, showTOPInfos[nowTitle])// 渲染TOP榜数据
                  nowIndex += 1;
                }, 60000); // 一分钟更新渲染一次数据
                clearInterval(timer);
              }
            }, 60000);
            

// 数据渲染

 // 渲染TOP数据  infos 所有分类TOP商品集合  ,name 当前infos 中对应枚举名, showInfos 当前展示分类TOP数据
setTopInfos(infos, name, showInfos)=>{
// TODO : 这里进行你的数据渲染
}

注意⚠️:

这里获取的数据通过枚举存储,例如
const list = {
‘水果’ : [
{ …… },
{ …… },
],
‘饮料’ : [
{ …… },
{ …… },
],
……
}
好处:便于区分数据,根据标识渲染匹配对应数据

相关推荐:
JavaScript简单倒计时效果的实现

相关文章:

  • 相机内外参实践之点云投影矢量图
  • 基于鸽群算法优化概率神经网络PNN的分类预测 - 附代码
  • DEC 深度编码聚类函数
  • Java可以传入任意类的公共类写法
  • 【Liunx】部署MariaDB
  • 儿童水杯上架亚马逊美国站CPC认证办理 ,常见儿童产品CPC认证测试要求
  • js控制手机蓝牙
  • pytorch框架学习(tensorboard的使用)
  • IP-guard flexpaper远程命令执行漏洞复现 [附POC]
  • 搜索引擎项目
  • 信道复用技术
  • ssm823基于ssm的心理预约咨询管理系统的设计与实现+vue
  • 如何实现MQTT协议数据传输?
  • 日志日常开发备用
  • 【R Error系列】r - fatal error : RcppEigen. h:没有这样的文件或目录
  • 【word密码】word设置只读方式的四个方法
  • 大数据毕业设计选题推荐-生产大数据平台-Hadoop-Spark-Hive
  • aliyun Rest ful api V3版本身份验证构造
  • 测试员练就什么本领可以让自己狂揽10个offer
  • 婴儿洗衣机哪个牌子比较好?好用的内衣洗衣机推荐
  • 机器人为啥热衷“搞体育”,经济日报:是向加速融入日常生活发起的冲锋
  • 官方通报汕头违建豪宅“英之园”将强拆:对有关人员严肃追责问责
  • 美联储官员:美国经济增速可能放缓,现行关税政策仍将导致物价上涨
  • 证监会:2024年依法从严查办证券期货违法案件739件,作出处罚决定592件、同比增10%
  • “养胃骗局”大公开,真正有用的方法究竟是?
  • “85后”贵阳市政府驻重庆办事处主任吴育材拟任新职