首页
学习
活动
专区
圈层
工具
发布

js滚动加载(无限加载)(转)

实现无限分页的过程大致如下: 1 视窗滚动到底部 2 触发加载,添加到现有内容的后面。 因此,可能会出现两种情况: 1 当页面的内容很少,没有出现滚动条。 2 当页面的内容很多,出现了滚动条。...针对这两种情况,需要理解几个概念: scrollHeight即真实内容的高度; clientHeight比较好理解,是视窗的高度,就是我们在浏览器中所能看到内容的高度; scrollTop是视窗上面隐藏掉的部分...实现的思路: 1 如果真实的内容比视窗高度小,则一直加载到超过视窗 2 如果超过了视窗,则判断下面隐藏的部分的距离是否小于一定的值,如果是,则触发加载。(即滚动到了底部)

21.3K20

无限滚动加载最佳实践

优秀无限滚动的五项原则 将无限滚动做好,并不是不可能完成的任务。为了完成它,记住并遵守以下方针。 1....如果屏幕上是滚动的内容,用户滚动获取新内容的时候,导航条可以隐藏起来;当用户开始往回滚动试图回到顶部的时候再显示出来。 ? 2. 如果有页脚,加上“加载更多”按钮 无限滚动阻碍用户的访问页脚。...实际上,这也是无限滚动设计的主要挑战之一:用户到达列表底部的时候,内容在不断地加载进来,用户会有一两秒时间看到页脚,直到下一组结果加载成功并将页脚挤出视图之外。这阻止用户接触到页脚。...返回按钮将用户待回至之前的位置 有时候,无限滚动的实现带来一个主要的可用性缺陷:滚动位置并未被记录为“状态”。如果用户从列表中的链接跳转了,然后点返回按钮,他们希望能回到页面原来相同的位置。...结论 无限滚动实现得好的话,可以达到令人难以置信的光滑无缝体验。很好的是,关于好的无限滚动,你已经获得一些线索了,这会帮你建立完美的用户体验。

5.5K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    让Typecho无限滚动加载的方法

    据统计,据媒体报道,据各种经验之谈:用户不喜欢点击,更爱滚动!所以,之前挺流行的文章分页没有了,沿用了几百年的“下一页”也被无限load取代。瀑布流和Twitter更是推动了无限load的普及。...这里介绍一个jQuery插件:Infinite AJAX Scroll,通过这个插件能快速实现无限滚动翻页。因为是jQuery所以到处都能用,这里我们以Typecho作为例子。...第一步接入Infinite AJAX Scroll 下载Infinite AJAX Scroll,放到对应主题的js文件夹中。因为是jQuery插件,我们还要先连上jQuery。...(new IASTriggerExtension({ text: '加载更多', //此选项为需要点击时的文字 offset: 2, //load多少页后显示加载更多按钮...为了更方便理解,我偷了个图,基本就是这样的 3460088466.jpg 步骤四重载函数 因为文章可能含有缩略图,而缩略图可能会用到惰性加载的js,所以ajax加载文章后,缩略图可能加载异常,这时我们需要在步骤三的代码最后加上一条

    2.4K20

    滑动到底部无限加载的实现

    我们常常会碰到数据条数很多,需要分页显示的情况。对于移动端页面,我们一般会用每次滚动到接近页面底部时,加载更多(下一页)数据的方式。本文就来介绍下滑动到底部无限加载的实现。...实现滑动到底部无限加载,我们要做的是: 监听显示数据内容的元素的滚动事件。 每次元素滚动时,若此时不在加载数据,则计算元素下方没显示的高度值。...如果其值小于我们设定的触发加载的值,则加载,显示更多数据;否则什么都不做。 如果没有更多的内容可显示,则不再监视元素的滚动事件。...易知:元素下方没显示的高度值 = 元素总高度 - 元素垂直方向滚动了的距离 - 元素可视区域高度 各种值如下图所示: ?...jQuery Infinite Scrolling Demos 无限加载 grid 的列表,文章,图片带分页等。

    2.1K20

    Vue组件滚动加载、懒加载功能的实现,无限滚动加载组件实例演示

    效果图如下: 可以看到随着不断的滚动,页面组件的数量不断的加载。 其实加载的是后端返回的数据,因为涉及隐私,没有给显示出来。 利用懒加载,可以防止大量渲染造成卡顿降低用户体验。...页面的动态加载这块可以看上一篇文章: Vue 动态添加和删除组件的实现,子组件和父组件的传值实例演示 下面主要讲一下动态加载的实现思路: 首先懒加载主要有两种形式,一种是不断的从后端请求返回前端,每次获取一部分数据...window.addEventListener('scroll', this.rolling); 当检测滚动条滚到底部时,加载数据。...当滚动过的距离 + 可视区的高度 >= 滚动条长度时,就相当于滚动到了底部。...= document.documentElement.scrollHeight // 当滚动过的距离+可视区的高度>=滚动条长度时,就相当于滚动到了底部 if (scrollTop

    5.8K50

    Flutter-ListView组件下拉刷新+滚动底部加载+缓存封装

    Flutter的ListView组件,虽然很好用,但是数据量大的时候,在低配置的机器上会奇卡无比,所以我封装了一个ListView组件,对数据进行截断,并使用 keframe 插件进行流畅性优化,提升低配置设备的用户体验...flutter_easyloading/flutter_easyloading.dart';//后续去除 import 'package:keframe/size_cache_widget.dart'; /// 可缓存+下拉刷新+滚动到底部自动加载的...ThemeData.canvasColor notificationPredicate: defaultScrollNotificationPredicate, //是否应处理滚动通知的检查...= null) { _pageCount = -1; //使用自定义方法加载数据,除第一次加载数据后则无需pageCount。...CacheTableList( tableList: ["列表内容1","列表内容2","列表内容3","列表内容4","列表内容5","列表内容6"], pageCount: 3,//上面6笔静态数据,会以每三笔的方式加载

    1.3K10

    掌握Intersection Observer API,轻松实现实现图片懒加载、元素滚动动画、无限滚动加载等功能

    掌握Intersection Observer API,轻松实现实现图片懒加载、元素滚动动画、无限滚动加载等功能 一、什么是 Intersection Observer API?...在它出现之前,通常我们需要这么做: window.addEventListener('scroll', function () { const rect = element.getBoundingClientRect...}); }); onBeforeUnmount(() => { if (observer) { observer.disconnect(); } }); 4、无限滚动...(加载更多) 滚到底部时自动加载新数据即可,这里只给一个简单的demo,实际实现还需要考虑内存泄漏、用户操作友好性等问题。...,你可以轻松实现图片懒加载、元素滚动动画、无限滚动加载、页面性能优化等目的。

    71110

    jquery scroll 滚动加载列表 获取腾讯云图片像素信息

    jquery scroll 滚动加载列表 获取腾讯云图片像素信息 场景描述 问题处理 其他问题处理 场景描述 bootstarp列表加载图片时需要同时获取图片的像素(宽and高),对于腾讯云这类远程存储获取图片来说...,并且腾讯云获取图片像素信息的接口还有频限100的限制,这就更导致了通过后台获取图片像素方案的不适用,那么如果通过页面jquery获取图片像素的时候当图片量很大的时候也是会出现卡顿,加载慢的情况,这个时候就考虑的热区内图片展示像素...用于监听元素是否进入可视区 $('#tableDiv').scroll(function () { start(); }) } 效果如图 初始化列表时执行一次start(),给热区内图片赋值像素,待滚动鼠标时再拉去当前页面热区内未加载图片像素信息的图片像素...其他问题处理 由于业务需要,除了列表页,我们同时增加了视图模式,效果如图 列表增加了滚动加载图片像素信息的方法,那么视图模式同样也需要,视图代码结构 增加start1()方法用于针对视图模式处理 var...('scroll'); } } 视图模式的加载效果 既然加了视图模式,那么就会涉及到视图和列表切换时方法的销毁问题,因为不销毁的话,在列表模式下,滚动的话也会执行视图模式的滚动方法导致资源浪费,关闭滚动方法的处理如下

    1.7K10

    摸鱼的新发现,滚动条无限滚动

    掘金官网的滚动条当你拖动到底部的时候会自动回弹到一定的位置。顺着这个问题,我想着使用 vue-cli3.0 和 TS 实现以下这个功能。...ElementClass extends Vue {} interface IntrinsicElements { [elem: string]: any } } } Element-ui 的无限滚动...使用count模拟初始数据,滚动到底部的时候触发 load 方法通过 push 方法模拟滚动请求回来的数据。...首先需要获取滚动条的位置,即可视区的高度和内容区域底部距离可视区页面顶部的距离,如果他们相等此时浏览器的滚动条当好滚动到页面底部,如果相差是负数说明浏览器的滚动条还没有到达页面底部。 ?...其实无限滚动也简单,就是能不能想到这个点子上,如果想不到那肯定就是天方夜谭了,这里面也有很多不足的地方需要改进,欢迎留言探讨和指点,毕竟这里的水很深,不小心鞋就湿了。

    2.3K40

    使用Ionic React实现的无限滚动效果

    Ionic React 是今年新出的版本 官网 https://ionicframework.com/docs/react 开始之前 在我们创建一个无限滚动项目之前,我们需要一个 Ionic.../src/pages/Tab1.tsx 当我们要实现无限滚动并因此要显示一个列表时,我们要做的第一件事情就是添加一个应包含项目的Stateful Value....所以,在使用的过程中,很有可能会有重复的“狗狗”。 加载初始数据 Ionic 提供了我们可以在应用程序中使用的多个生命周期事件,它不仅为标准组件库提供了这类事件,也同样为功能组件提供了类似事件。...所以现在,我们要来实现无限滚动,首先,添加一个新的功能,该功能将帮助我们获取新的数据并且告诉滚动器该操作已经完成了。...await fetchData(); ($event.target as HTMLIonInfiniteScrollElement).complete(); } 最后,我们将Ionic的无限滚动组件导入

    4.2K60

    基于 Vue.js 的移动端组件库mint-ui实现无限滚动加载更多

    通过多次爬坑,发现了这些监听滚动来加载更多的组件的共同点, 因为这些加载更多的方法是绑定在需要加载更多的内容的元素上的, 所以是进入页面则直接触发一次,当监听到滚动事件之后,继续加载更多, 所以对于无限滚动加载不需要写首次载入列表的函数...vue.js data: page:0, size:10, loadingTextBtn:false, loadingText:"努力加载中...this.size}); this.page++; }, 1000); }else{ this.loadingText="已全部加载完成...0的时候,即第一页的时候,不需要setTimeout定时器,直接请求加载,当加载更多的时候可以加个定时器。...网上找到很多mint-ui 的loadmore组件来实现上拉加载更多,由于上拉触发相应的加载更多事件,所以当进入页面的时候应该不会自动载入数据,则这里可以加一个获取第一页数据的函数。

    3.1K50
    领券