layui——flow组件常见用法总结

Posted 杨治中

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了layui——flow组件常见用法总结相关的知识,希望对你有一定的参考价值。

  该模块包含 信息流加载 和  图片懒加载  两大核心支持,无论是对服务端、还是前端体验,都有非常大的性能帮助。下边分别给出了这两种技术的使用方法

一、信息流加载

  信息流加载的核心方法时  flow.load(options) ,下边给了一个模拟加载新闻列表的栗子

前端html和js

    <style>
        ul li 
            height: 200px;
            border: 5px solid green;
            font-size: 50px;
            line-height: 200px;
            text-align: center;
        
    </style>
    <ul id="newsList"></ul>
    <!-- 条目中可以是任意内容,如:<img src=""> -->
    <script src="~/Content/layui/layui.js"></script>
    <script>
        layui.use('flow', function () 
            var $ = layui.jquery; //不用额外加载jQuery,flow模块本身是有依赖jQuery的,直接用即可。
            var flow = layui.flow;
            flow.load(
                elem: '#newsList'    //指定列表容器
                , isAuto: false      //到底页面底端自动加载下一页,设为false则点击'加载更多'才会加载
                //, mb: 100          //距离底端多少像素触发auto加载
                , isLazying: true    //当单个li很长时,内部有很多图片,对图片进行懒加载,默认false。
                , end: '<p style="color:red">木有了</p>'    //加载所有后显示文本,默认'没有更多了'
                , done: function (page, next)             //到达临界,触发下一页
                    var lis = [];
                    $.get('/Home/GetList?page=' + page, function (res) 
                        //假设你的列表返回在data集合中
                        layui.each(res.data, function (index, item) 
                            lis.push('<li>' + item + '</li>');
                        );
                        next(lis.join(''), page < res.pages);//pages是后台返回的总页数
                    );
                
            );
        );
    </script>

后台服务器代码

    public class HomeController : Controller
    
        // GET: Home
        public ActionResult Index()
        
            return View();
        
        public ActionResult GetList(int page)
        
           //简单数据库中新闻
            List<string> newsList = new List<string>();
            for (int i = 0; i < 55; i++)
            
                newsList.Add("新闻" + i);
            
           //总页数
            int pages =(int) Math.Ceiling((double)55 / 10);
       //模拟分页
            var data= newsList.Skip<string>((page - 1) * 10).Take(10);
            return Json(new  data,pages,JsonRequestBehavior.AllowGet);
        
    

二、图片懒加载

  layui中的图片懒加载十分简单,将图片的src属性替换为lay-src,然后调用  flow.lazyimg() 方法即可

layui.use('flow', function()
  var flow = layui.flow;
  //当你执行这样一个方法时,即对页面中的全部带有lay-src的img元素开启了懒加载
    flow.lazyimg();    //方式一,全部懒加载
    flow.lazyimg(     //方式二,特定容器懒加载
    elem:'#box1'      //不设置elem,对页面中所有图片进行懒加载
    ,scrollElem:document
    ) 
);

:这是为了个人查找方便整理的文档,并没有总结完全,查看更多可访问官网

以上是关于layui——flow组件常见用法总结的主要内容,如果未能解决你的问题,请参考以下文章

手动封装分页组件(Vue3)

layui 滚动加载

layUI独立组件layer-laydate-laypage项目实践用法

layui flow loading占位图实现方法

EasyUI——常见用法总结

layui flow loading占位图实现方法