首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

无限滚动加载最佳实践

优秀无限滚动的五项原则 将无限滚动做好,并不是不可能完成的任务。为了完成它,记住并遵守以下方针。 1....如果屏幕上是滚动的内容,用户滚动获取新内容的时候,导航条可以隐藏起来;当用户开始往回滚动试图回到顶部的时候再显示出来。 ? 2. 如果有页脚,加上“加载更多”按钮 无限滚动阻碍用户的访问页脚。...实际上,这也是无限滚动设计的主要挑战之一:用户到达列表底部的时候,内容在不断地加载进来,用户会有一两秒时间看到页脚,直到下一组结果加载成功并将页脚挤出视图之外。这阻止用户接触到页脚。...结论 无限滚动实现得好的话,可以达到令人难以置信的光滑无缝体验。很好的是,关于好的无限滚动,你已经获得一些线索了,这会帮你建立完美的用户体验。...---- 往期精选文章 使用虚拟dom和JavaScript构建完全响应式的UI框架 扩展 Vue 组件 使用Three.js制作酷炫无比的无穷隧道特效 一个治愈JavaScript疲劳的学习计划 全栈工程师技能大全

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

    让Typecho无限滚动加载的方法

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

    1.6K20

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

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

    3.6K40

    网站页面滚动加载动画JS特效

    终于尘埃落定了,前段时间忙的不可开交,结婚,工作,因为婚假+年假一起休的,导致很长时间没有更新博客了,今天抽空给大家带来了一个js特效,网站模块延迟加载的动画,假期之前就想着制作这个功能,页面滚动加载...简介 和 WOW.js 一样,scrollReveal.js 也是一款页面滚动显示动画的 JavaScript,能让页面更加有趣,更吸引用户眼球。...不同的是 WOW.js 的动画只播放一次,而 scrollReveal.js 的动画可以播放一次或无限次;WOW.js 依赖 animate.css,而 scrollReveal.js 不依赖其他任何文件...container'); container.innerHTML(data.newElementHTML); scrollReveal.init(); 其中高级自定义可以在后期加入,目前本站只是简单的加载动画...如果不喜欢这个可以试试wow.js,网站页面滚动加载动画JS特效(二)。

    11.4K20

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

    通过多次爬坑,发现了这些监听滚动加载更多的组件的共同点, 因为这些加载更多的方法是绑定在需要加载更多的内容的元素上的, 所以是进入页面则直接触发一次,当监听到滚动事件之后,继续加载更多, 所以对于无限滚动加载不需要写首次载入列表的函数...item.commentCount}} vue.js...this.loading = false; } }, 这里重要的是判断,当当前页面为0的时候,即第一页的时候,不需要setTimeout定时器,直接请求加载...,当加载更多的时候可以加个定时器。...网上找到很多mint-ui 的loadmore组件来实现上拉加载更多,由于上拉触发相应的加载更多事件,所以当进入页面的时候应该不会自动载入数据,则这里可以加一个获取第一页数据的函数。

    2.6K50

    JS实现无限分页加载——原理图解

    由于网页的执行都是单线程的,在JS执行的过程中,页面会呈现阻塞状态。因此,如果JS处理的数据量过大,过程复杂,可能会造成页面的卡顿。...有很多网站使用 无限分页 的模式,即网页视窗到达内容底部就自动加载下一部分的内容... 本篇就无限分页的实现模型,讲述其中奥妙。...原理图 实现无限分页的过程大致如下: 1 视窗滚动到底部 2 触发加载,添加到现有内容的后面。 因此,可能会出现两种情况: 1 当页面的内容很少,没有出现滚动条。...(即滚动到了底部) 代码样例 代码部分没有太多的内容,需要注意的是: 1 使用fixed定位加载框 2 使用setTimeout定时触发判断方法,频率可以自定义 3 通过 真实内容高度 - 视窗高度 -...当向下滚动了一下后,视窗的高度不变;上面隐藏的高度增加到100,即滚动条上面代表的部分。 ? 当触发加载后,视窗的高度保持变;上面隐藏的高度保持不变;文本的内容增加到1816; ?

    5.9K100

    网站页面滚动加载动画JS特效(二)

    昨天发布了网站页面滚动加载动画JS特效,但是加载的页面并不怎么完美,文章页面不能直接加载出来,需要滚动条继续下来,可能是没有调节js导致的,所以今天又重新测试了wow.js,感觉这个不错,很喜欢,有兴趣的可以测试下...页面在向下滚动的时候,有些元素会产生细小的动画效果。虽然动画比较小,但却能吸引你的注意。比如刚刚发布的 iPhone 6 的页面(查看)。如果你希望你的页面也更加有趣,那么你可以试试 WOW.js。...WOW.js 依赖 animate.css,所以它支持 animate.css 多达 60 多种的动画效果,能满足您的各种需求。 ?...使用方法 1、引入文件(自带的css样式) 2、HTML(给需要滚动动画的div增加两个css属性) <div...animated’ animation.css 动画的 class offset 整数 0 距离可视区域多少开始执行动画 mobile 布尔值 true 是否在移动设备上执行动画 live 布尔值 true 异步加载的内容是否有效

    7.4K30

    一款用于 Vue.js无限滚动插件

    本文由 #公众号:一个正经的程序员 原创 作者:散淡样子 GitHub:https://github.com/LouisLiu00 00 前言 Web 项目经常会用到下拉滚动加载数据的功能,今天就来种草一款...(文末附链接) 开箱即用: 简洁至上的 API、内置加载动画以及良好的兼容性,可立即投入生产 双向支持: 目前支持向上和向下两种加载方式,可适应于更多的应用场景 结果展示: 可配置的加载结果展示,比如没有更多数据...--infinite-loading这个组件要放在列表的底部,滚动的盒子里面!...; if (this.list.length / 10 === 10) { // 这里是加载了..., loaded方法用于在每次加载数据后停止播放动画,然后该组件将准备好进行下一次触发; complete方法用于完成完整的无限加载,则该组件将不再处理任何滚动操作。

    40820

    小程序无限加载

    小程序无限加载 什么是无限加载呢? 比如 刷朋友圈的时候,一直往下拉一直都会有内容 就像没有尽头一样,可以不断的加载出东西来,也可以叫滚动加载。...思路: 小程序的页面滚动到底部的时候,会触发一个onReachBottom方法,在这个方法里我们可以去实现加载下一页内容项目的功能。...利用这些信息,结合onReachBottom就可以实现无限加载功能了。...可以在小程序页面的数据(data)里面记录一下分页的状态,比如当前页(currentPage)每次滚动到页面底部的时候,就重新设置一下currentPage的值,让它加上 1 ,然后去载入下一页的内容,...每次加载几条可以后台设置. 遗留问题: app.json 中的这一项以为需要配置 但是试了写上和不写没什么区别有知道的请留言 还有如果有更好的办法做无限加载 tell me ,thanks

    2.6K50

    iOS开发之UIScrollView无限滚动

    UIScrollView 的无限滚动主要应用在图片轮播器、欢迎界面等场景。首先需要说明的是,文本所讲的是一种"笨办法",但是好理解且容易实现,在图片不多的时候用它也无妨。...它的原理是在要显示的图片前后各加一张图片即在第一张图片之前放最后一张图片,在最后一张图片之后放第一张图片,然后在滚动到边缘的时候,巧妙的过渡一下就可以"瞒天过海","以假乱真"的造成无限滚动的假象。...2、代码实现,主要分为:添加UIScrollView,添加显示图片,添加UIPageControl,然后监听UIScrollView的滚动,根据滚动的位置来设置UIPageControl,最重要的是对于滚动到两个边缘时要特殊处理一下...要展示的图片数组 @property(strong, nonatomic) NSMutableArray *imgArray; @end @implementation ViewController //懒加载数组...图片无限轮播.gif 写在后面的话 其实实现轮播现在最好的方案应该是使用UICollectionView,因为它是利用重用机制来实现的,性能会好很多,代码写起来类似。

    1.7K100

    Android ListView实现无限循环滚动

    本文实例为大家分享了Android无限循环滚动的具体代码,供大家参考,具体内容如下 因项目需要循环展示列表数据,所以就实现了这个无限循环滚动的 LIstView.先说一下原理,原理呢,其实很简单,首先将要展示的数据循环展示三遍...监听ListView的滚动事件,当ListView滚动到第一遍第第二个时,ListView变自动跳到第二遍的第二个,同理,如果ListView滚动到倒数第一个时,ListView自动跳转到第二遍的倒数第一个...//取余展示数据 return convertView; } static class ViewHoler{ TextView tvText; } } 然后实现监听ListView的滚动事件...,当滚动到第二个时,跳到地list.size()+2个,滚动到倒数第二个时,跳到中间第二个,setSelection时, * 由于listView滚动并未停止,所以setSelection后会继续滚动...listView.setSelection(firstVisibleItem - list.size()); } } } 就是这么简单,嘿嘿,表达能力有点欠缺,不知到你看懂没,没看懂的话,后面附上源码:Android无限循环滚动

    3.1K31

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

    extends Vue {} interface IntrinsicElements { [elem: string]: any } } } Element-ui 的无限滚动...(tsx 版本) ts 版本和之前的 js 版本差距不适合很大,写法类似于 react,采用了 class 类声明变量和声明方法的时候直接用即可。...使用count模拟初始数据,滚动到底部的时候触发 load 方法通过 push 方法模拟滚动请求回来的数据。...首先需要获取滚动条的位置,即可视区的高度和内容区域底部距离可视区页面顶部的距离,如果他们相等此时浏览器的滚动条当好滚动到页面底部,如果相差是负数说明浏览器的滚动条还没有到达页面底部。 ?...setTimeout(fn, wait); }; } 源码已放到 github 上:https://github.com/clown-Jack/vue-scroll 总结 回顾一下上面的所想的,其实无限滚动也简单

    1.9K40
    领券