首页 > 语言 > JavaScript > 正文

使用MUI框架模拟手机端的下拉刷新和上拉加载功能

2024-05-06 15:11:54
字体:
来源:转载
供稿:网友

mui框架基于htm5plus的XMLHttpRequest,封装了常用的Ajax函数,支持GET、POST请求方式,支持返回json、xml、html、text、script数据类型; 本着极简的设计原则,mui提供了mui.ajax方法,并在mui.ajax方法基础上,进一步简化出最常用的mui.get()、mui.getJSON()、mui.post()三个方法。

套用mui官方文档的一句话:“开发者只需关心业务逻辑,实现加载更多数据即可”。真的是不错的框架。

想更多的了解这个框架:http://dev.dcloud.net.cn/mui/

那么如何实现下拉刷新,上拉加载的功能呢?

首先需要一个容器:

<!--下拉刷新容器--><div id="refreshContainer" class="mui-content mui-scroll-wrapper">  <div class="mui-scroll">  <!--数据列表-->    <ul id="testUl" class="mui-table-view mui-table-view-chevron"></ul>  </div></div>

然后进行初始化操作,通过mui.init方法中pullRefresh参数配置上拉加载各项参数:

mui.init({ pullRefresh : { container:refreshContainer,//待刷新区域标识,querySelector能定位的css选择器均可,比如:id、.class等 up : { height:50,//可选.默认50.触发上拉加载拖动距离 auto:true,//可选,默认false.自动上拉加载一次 contentrefresh : "正在加载...",//可选,正在加载状态时,上拉加载控件上显示的标题内容 contentnomore:'没有更多数据了',//可选,请求完毕若没有更多数据时显示的提醒内容; callback :pullfresh-function //必选,刷新函数,根据具体业务来编写,比如通过ajax从服务器获取新数据; } }});

这里重点关注callback参数项,为必选内容,里边写刷新函数,根据具体的业务来写,在实际项目中,通常是通过ajax从服务器获取数据,然后进行html的动态拼接,形成数据项。

下面举一个很简单的例子:(实现上拉加载的功能)

容器:

 <!--下拉刷新容器--> <div id="refreshContainer" class="mui-content mui-scroll-wrapper">  <div class="mui-scroll">  <!--数据列表-->     <ul id="testUl" class="mui-table-view mui-table-view-chevron"></ul>  </div> </div>

一会要将数据放到 id=“testUl”的ul标签下,id当然随便取

调用mui.init方法:

<script type="text/javascript"> mui.init({  pullRefresh : {   container:refreshContainer,//待刷新区域标识,querySelector能定位的css选择器均可,比如:id、.class等   up : {    height:50,//可选.默认50.触发上拉加载拖动距离    auto:true,//可选,默认false.自动上拉加载一次    contentrefresh : "正在加载...",//可选,正在加载状态时,上拉加载控件上显示的标题内容    contentnomore:'没有更多数据了',//可选,请求完毕若没有更多数据时显示的提醒内容;    callback: function () {//必选,刷新函数,根据具体业务来编写,比如通过ajax从服务器获取新数据;     /*每次加载动态的添加一个li*/     $("#testUl").append($("<li>" + new Date() + "</li>"));     this.endPullupToRefresh(false);    }     }    }    });</script>            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选