摘要:实现列表动态无限滚动问题在开发页面工程中,经常会遇到滚动列表当实际需要显示的内容宽度或高度超过容器的宽度或高度时,设置当滚动列表中的内容比较少时,我们可以一次性加载所有的内容到列表容器中显示。
JS+HTML实现列表动态无限滚动 问题
在HTML开发页面工程中,经常会遇到滚动列表-当实际需要显示的内容宽度或高度超过容器的宽度或高度时,设置CSS
overflow-x:auto; overfow-y:auto;
当滚动列表中的内容比较少时,我们可以一次性加载所有的内容到列表容器中显示。
当滚动列表中的内容比较多,使用分页加载的方式逐步加载数据,2种方式
1.通过在列表的末尾添加一个标别元素indicator,和添加列表的scroll事件来监听indicator元素是否可见,如果可见那么提交请求加载下一页数据,append到列表内容的尾部。通过这个方式可以实现数据的无限加载,一直到数据取完。
2.在列表下部添加分页工具条,用户通过请求获取指定页的数据并且替换到当前列表里的内容
对于方式1对用户想对友好,加载过的数据不会重复加载,请求的资源少,但是当量多时,页面上的DOM元素量很不断增加,消耗的内存也会加大
方式2用户每翻一页都要重新请求数据,即使对于翻过看过的数据想要重新看也是如此,请求资源多,好处是页面DOM元素数量固定,占用内存资源少
那么有没有一种方式结合方式1和方式2的优点,摒弃缺点,融合优化下呢?
~~有!有方法~~解决方案:
对当前列表的宽高固定,对列表包含的内容高度固定,列表滚动满足条件时动态删除或添加元素,保持元素数量的固定已经内容在列表可视区域的正确显示。
列表能够无限滚动,数据能够无限加载,DOM元素保持一定数量
先放出实现的代码吧
HTML部分Title 123456789101112131415161718192021222324252627282930
.infinity-scroll指定列表容器,CSS设置其水平不滚动,垂直方向自动滚动
.main-content为滚动内容组件,其高度随着实际内容的增多而加大
.item为滚动内容的单个项目元素
.first-item为当前放置在列表容器内的内容的第1个元素,同时为当前滚动到顶部的标识元素
.last-item为当前放置在列表容器内的内容的最后一个元素,同时为当前滚动到底部的标识元素
放3组元素作为初始的列表内容,为什么是3组呢?为了保证滚动的流畅性,当前列表窗口显示一组,卷起一组,下部隐藏一组
JS部分$(".infinity-scroll").on("scroll",infinity_scrollFun);
为列表添加scroll事件监听infinity_scrollFun
infinity_scrollFun函数
计算列表容器的高度和离viewpoint顶部距离
if(!infinity_scroll_height){ infinity_scroll_height=$(".infinity-scroll")[0].getBoundingClientRect().height; infinity_scroll_top=$(".infinity-scroll")[0].getBoundingClientRect().top; }
计算.last-item的位置,如果正在加载数据不执行任何动作
if(isLoading){ return; }else{ last_item_top=$(".item.last-item")[0].getBoundingClientRect().top; last_item_top=last_item_top-infinity_scroll_top; }
如果.last-item出现在列表窗口,那么加载新的数据
if(last_item_top<=infinity_scroll_height){ isLoading=true; appendNewItems($(".main-content")[0].getBoundingClientRect().height,$(this).scrollTop()); return; }
如果.first-item出现在列表窗口,那么restore原来已经加载过的数据
first_item_top=$(".item.first-item")[0].getBoundingClientRect().top; first_item_top=first_item_top-infinity_scroll_top; console.log("~~first_item_top~~~%s",first_item_top); if(first_item_top>=0){ restorePreItems($(".main-content")[0].getBoundingClientRect().height,$(this).scrollTop()); return; }
appendNewItems函数
保持总体元素的个数,将.first-item后的10个元素删除,添加新的内容到底部,并要保持内容的实际高度及显示在列表窗口的内容的位置
$(".item").slice(0,10).remove(); $(".item").first().addClass("first-item"); var mainContentPaddingTop=$(".main-content").css("padding-top"); mainContentPaddingTop=parseFloat(mainContentPaddingTop.split("px")[0]||0); $(".main-content").append(documentFragment); if(lastMaxItemIndexrestorePreItems函数
功能和appendNewItems函数类似,只是删除底部的10个元素,添加10个元素到头部,并要保持内容的实际高度及显示在列表窗口的内容的位置//删除尾部的10个元素 $(".item.last-item").prevAll().slice(0,9).remove(); $(".item.last-item").remove(); $(".item").last().addClass("last-item"); mainContentPaddingTop=$(".main-content").css("padding-top"); mainContentPaddingTop=parseFloat(mainContentPaddingTop.split("px")[0]||0); $(".main-content").css({ "padding-top":mainContentPaddingTop-10*50 }); $(".main-content").prepend(documentFragment); $(".infinity-scroll").off("scroll",infinity_scrollFun); $(".infinity-scroll").scrollTop(scroll_top); $(".infinity-scroll").on("scroll",infinity_scrollFun);待改进的地方上面的假设内容区的item的高度都是相同,并且每次加在的item数量都是相同的。如果内容item的高度是动态变化的;
同时没有做到页面DOM元素的复用,其实完全可以复用删除的元素作为将要添加的元素,只是变更其中的数据显示内容;代码需要做相应的修改,就留给小伙伴们改进吧:)
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/82068.html
摘要:实现列表动态无限滚动问题在开发页面工程中,经常会遇到滚动列表当实际需要显示的内容宽度或高度超过容器的宽度或高度时,设置当滚动列表中的内容比较少时,我们可以一次性加载所有的内容到列表容器中显示。 JS+HTML实现列表动态无限滚动 问题 在HTML开发页面工程中,经常会遇到滚动列表-当实际需要显示的内容宽度或高度超过容器的宽度或高度时,设置CSS overflow-x:auto;...
摘要:虚拟列表的实现有多种方案,本文以组件为基础进行分析。常见的无限滚动便是延迟渲染的一种实现,而虚拟列表则是按需渲染的一种实现。接下来,本文会简单介绍虚拟列表的一种实现方案。实现本章节将会创建一个组件,并结合代码,慢慢梳理虚拟列表的实现。 在 列表数据的展示优化 一文中,提到了对于列表形态的数据展示的按需渲染。这种方式是指根据容器元素的高度以及列表项元素的高度来显示长列表数据中的某一个部分...
摘要:合理的优化长列表,可以提升用户体验。这样保证了无论如何滚动,真实渲染出的节点只有可视区内的列表元素。具体效果如下图所示对于比无优化的情况,优化后的虚拟列表渲染速度提升很明显。是基于来实现的,但是是一个维的列表,而不是网状。 对于较长的列表,比如1000个数组的数据结构,如果想要同时渲染这1000个数据,生成相应的1000个原生dom,我们知道原生的dom元素是很复杂的,如果长列表...
摘要:合理的优化长列表,可以提升用户体验。这样保证了无论如何滚动,真实渲染出的节点只有可视区内的列表元素。具体效果如下图所示对于比无优化的情况,优化后的虚拟列表渲染速度提升很明显。是基于来实现的,但是是一个维的列表,而不是网状。 对于较长的列表,比如1000个数组的数据结构,如果想要同时渲染这1000个数据,生成相应的1000个原生dom,我们知道原生的dom元素是很复杂的,如果长列表...
阅读 3895·2021-11-24 11:14
阅读 3337·2021-11-22 13:53
阅读 3900·2021-11-11 16:54
阅读 1587·2021-10-13 09:49
阅读 1234·2021-10-08 10:05
阅读 3411·2021-09-22 15:57
阅读 1766·2021-08-16 11:01
阅读 982·2019-08-30 15:55