相思资源网 Design By www.200059.com
原生app里的数据列表都会使用下拉刷新的效果,在webapp里可以采用iscroll、swiper等插件或框架实现,那么如何自己编码实现类似的效果呢,下面介绍使用原生js+css3实现的简单效果。
html布局
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no"> <title>test</title> <style type="text/css" media="screen"> body{margin: 0;} ul{list-style: none;padding: 0;} li{height: 30px;border-bottom: 1px solid #ddd;line-height: 30px;padding-left: 10px;} .scroller .loading{height: 60px;line-height: 60px;text-align: center;width: 100%;background-color: #f1f1f1;} .scroller{-webkit-overflow-scrolling:touch;} </style> </head> <body > <div id="container" class="scroller" > <div class="loading"> 下拉刷新数据 </div> <ul> <li><a href="#">列表数据1</a></li> <li><a href="#">列表数据2</a></li> <li><a href="#">列表数据3</a></li> <li><a href="#">列表数据4</a></li> <li><a href="#">列表数据5</a></li> <li><a href="#">列表数据6</a></li> <li><a href="#">列表数据7</a></li> <li><a href="#">列表数据8</a></li> <li><a href="#">列表数据9</a></li> <li><a href="#">列表数据10</a></li> <li><a href="#">列表数据11</a></li> <li><a href="#">列表数据12</a></li> <li><a href="#">列表数据13</a></li> <li><a href="#">列表数据14</a></li> <li><a href="#">列表数据15</a></li> <li><a href="#">列表数据16</a></li> <li><a href="#">列表数据17</a></li> <li><a href="#">列表数据18</a></li> <li><a href="#">列表数据19</a></li> <li><a href="#">列表数据20</a></li> <li><a href="#">列表数据21</a></li> <li><a href="#">列表数据22</a></li> <li><a href="#">列表数据23</a></li> <li><a href="#">列表数据24</a></li> <li><a href="#">列表数据25</a></li> <li><a href="#">列表数据26</a></li> <li><a href="#">列表数据27</a></li> <li><a href="#">列表数据28</a></li> <li><a href="#">列表数据29</a></li> <li><a href="#">列表数据30</a></li> </ul> </div> <body> </html>
js逻辑
var slide = function (option) { var defaults={ container:'', next:function(){} } var start, end, length, isLock = false,//是否锁定整个操作 isCanDo = false,//是否移动滑块 isTouchPad = (/hp-tablet/gi).test(navigator.appVersion), hasTouch = 'ontouchstart' in window && !isTouchPad; var obj = document.querySelector(option.container); var loading=obj.firstElementChild; var offset=loading.clientHeight; var objparent = obj.parentElement; /*操作方法*/ var fn = { //移动容器 translate: function (diff) { obj.style.webkitTransform='translate3d(0,'+diff+'px,0)'; obj.style.transform='translate3d(0,'+diff+'px,0)'; }, //设置效果时间 setTransition: function (time) { obj.style.webkitTransition='all '+time+'s'; obj.style.transition='all '+time+'s'; }, //返回到初始位置 back: function () { fn.translate(0 - offset); //标识操作完成 isLock = false; }, addEvent:function(element,event_name,event_fn){ if (element.addEventListener) { element.addEventListener(event_name, event_fn, false); } else if (element.attachEvent) { element.attachEvent('on' + event_name, event_fn); } else { element['on' + event_name] = event_fn; } } }; fn.translate(0-offset); fn.addEvent(obj,'touchstart',start); fn.addEvent(obj,'touchmove',move); fn.addEvent(obj,'touchend',end); fn.addEvent(obj,'mousedown',start) fn.addEvent(obj,'mousemove',move) fn.addEvent(obj,'mouseup',end) //滑动开始 function start(e) { if (objparent.scrollTop <= 0 && !isLock) { var even = typeof event == "undefined" "undefined" "function") { option.next.call(fn, e); } } else { //返回初始状态 fn.back(); } } } } slide({container:"#container",next: function (e) { //松手之后执行逻辑,ajax请求数据,数据返回后隐藏加载中提示 var that = this; setTimeout(function () { that.back.call(); }, 2000); }});
代码不是很多,细节还需完善。
相思资源网 Design By www.200059.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
相思资源网 Design By www.200059.com
暂无APP中javascript+css3实现下拉刷新效果的评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。