-

流加载文档 - layui.flow

该模块包含信息流加载图片懒加载两大核心支持,无论是对服务端、还是前端体验,都有非常大的性能帮助。你可能已经在太多的地方看到她们的身影了,但不妨现在开始,体验一下Layui更为简单和高效的Flow吧。

模块加载名称:flow

使用

flow模块包含两个核心方法,如下所示:

</>code

  1. layui.use('flow', function(){
  2. var flow = layui.flow;
  3. //信息流
  4. flow.load(options);
  5. //图片懒加载
  6. flow.lazyimg(options);
  7. });

下面将对她们进行详细介绍。

信息流

信息流即异步逐页渲染列表元素,这是你页面已经存在的一段列表,你页面初始时只显示了6个

HTMLcode

  1. <ul id="demo">
  2. <li>1</li>
  3. <li>2</li>
  4. ……
  5. <li>6</li>
  6. </ul>

你想通过加载更多来显示余下列表,那么你只需要执行方法:flow.load(options) 即可

JavaScriptcode

  1. layui.use('flow', function(){
  2. var $ = layui.jquery; //不用额外加载jQuery,flow模块本身是有依赖jQuery的,直接用即可。
  3. var flow = layui.flow;
  4. flow.load({
  5. elem: '#demo' //指定列表容器
  6. ,done: function(page, next){ //到达临界点(默认滚动触发),触发下一页
  7. var lis = [];
  8. //以jQuery的Ajax请求为例,请求下一页数据(注意:page是从2开始返回)
  9. $.get('/api/list?page='+page, function(res){
  10. //假设你的列表返回在data集合中
  11. layui.each(res.data, function(index, item){
  12. lis.push('<li>'+ item.title +'</li>');
  13. });
  14. //执行下一页渲染,第二参数为:满足“加载更多”的条件,即后面仍有分页
  15. //pages为Ajax返回的总页数,只有当前页小于总页数的情况下,才会继续出现加载更多
  16. next(lis.join(''), page < res.pages);
  17. });
  18. }
  19. });
  20. });

上述是一个比较简单的例子,以下是信息流完整的参数支撑(即options对象),它们将有助于你更灵活地应对各种场景

参数 类型 描述
elem string 指定列表容器的选择器
scrollElem string 滚动条所在元素选择器,默认document。如果你不是通过窗口滚动来触发流加载,而是页面中的某一个容器的滚动条,那么通过该参数指定即可。
isAuto boolean 是否自动加载。默认true。如果设为false,点会在列表底部生成一个“加载更多”的button,则只能点击它才会加载下一页数据。
end string 用于显示末页内容,可传入任意HTML字符。默认为:没有更多了
isLazyimg boolean 是否开启图片懒加载。默认false。如果设为true,则只会对在可视区域的图片进行按需加载。但与此同时,在拼接列表字符的时候,你不能给列表中的img元素赋值src,必须要用lay-src取代,如:

JavaScript片段code

  1. layui.each(res.data, function(index, item){
  2. lis.push('<li><img lay-src="'+ item.src +'"></li>');
  3. });
mb number 与底部的临界距离,默认50。即当滚动条与底部产生该距离时,触发加载。注意:只有在isAuto为true时有效。
额,等等。。mb=margin-bottom,可不是骂人的呀。
done function 到达临界点触发加载的回调。信息流最重要的一个存在。携带两个参数:

JavaScript片段code

  1. done: function(page, next){
  2. //请注意:layui 1.0.5 之前的版本是从第2页开始返回,也就是说你的第一页数据并非done来触发加载
  3. (为之前这个愚蠢的设计表示抱歉)
  4. //从 layui 1.0.5 的版本开始,page是从1开始返回,初始时即会执行一次done回调。
  5. //console.log(page) //获得当前页
  6. //执行下一页渲染,第二参数为:满足“加载更多”的条件,即后面仍有分页
  7. //只有当前页小于总页数的情况下,才会继续出现加载更多
  8. next('列表HTML片段', page < res.pages);
  9. }
图片懒加载

应该说比当前市面上任何一个懒加载的实现都更为强劲和轻量,她用不足80行代码巧妙地提供了一个始终加载当前屏图片的高性能方案(无论上滑还是下滑)。对你的网站因为图片可能带来的压力,可做出很好的应对。

语法:flow.lazyimg(options)

</>code

  1. layui.use('flow', function(){
  2. var flow = layui.flow;
  3. //当你执行这样一个方法时,即对页面中的全部带有 lay-src 的 img 元素开启了懒加载(当然你也可以指定相关 img)
  4. flow.lazyimg();
  5. });

如上所述,它只会针对以下 img 元素有效:

HTMLcode

  1. <img src="占位图地址" lay-src="预加载图地址">
  2. <img src="" src="bbb.jpg">
  3. <img src="" lay-src="ccc.jpg">
占位图功能为 layui 2.6.6 开始新增。 这本应在 1.0 就该支持,但由于重心在其他组件,导致姗姗来迟。

如你所见,图片懒加载的使用极其简单,其参数(options 对象)可支持的 key 如下表所示:

参数 类型 描述
elem string 指定开启懒加载的img元素选择器,如 elem: '.demo img' 或 elem: 'img.load'
scrollElem string 滚动条所在元素选择器,默认document。如果你不是通过窗口滚动来触发流加载,而是页面中的某一个容器的滚动条,那么通过该参数指定即可。
结语

如果还有各种流行的流加载,你可以给我们提供建议,我们会在layui后续版本中选择性加入。

layui - 在每一个细节中,用心与你沟通