js仿手机页面文件下拉刷新效果


Posted in Javascript onOctober 14, 2016

最后弄出了一个简单的下拉刷新页面的形式,还不算太复杂

要在仿真器下才能看到效果,比如chrome的里边(或者用手机浏览器查看,但测试发现有些浏览器有问题,目前手机猎豹是没问题的)

js仿手机页面文件下拉刷新效果

js仿手机页面文件下拉刷新效果

js仿手机页面文件下拉刷新效果

js仿手机页面文件下拉刷新效果

主要就是:

下拉-->提示松开刷新-->松开后-->开始刷新-->刷新成功后还原

html,css部分

style type="text/css">
 #slideDown{margin-top: 0;width: 100%;}
   #slideDown1,#slideDown2{width: 100%;height: 70px;;background: #e9f4f7;display: none;}
   #slideDown1{height: 20px;}
   #slideDown1>p,#slideDown2>p{margin: 20px auto;text-align:center;font-size: 14px;color: #37bbf5;}
</style>


 <div id="content">
  <div id="slideDown">
   <div id="slideDown1">
    <p>松开刷新</p>
   </div>
   <div id="slideDown2">
    <p>正在刷新 ...</p>
   </div>
  </div>
  <div class="myContent">
   <ul>
    <li>item1 -- item1 -- item1</li>
    <li>item2 -- item2 -- item2</li>
    <li>item3 -- item3 -- item3</li>
    <li>item4 -- item4 -- item4</li>
    <li>item5 -- item5 -- item5</li>
    <li>item6 -- item6 -- item6</li>
    <li>item7 -- item7 -- item7</li>
   </ul>
  </div>
 </div>

js部分:

主要就是为一个节点绑定事件,可以是整个body,按照实际来看

k_touch()函数是主要代码,目前主要涉及三个事件,touchstart  touchmove  touchend

这里获取touch点坐标是用pageX,pageY 当然不兼容的话先不考虑

因为是下滑才刷新,所以稍微控制一下way,其实也就是通过这个控制是获取pageX 还是pageY

滑一滑可以直接看到dist的变化,其实就把它看做px了吧

js仿手机页面文件下拉刷新效果

更多的功能,以后再说吧..

<script type="text/javascript">
 //第一步:下拉过程
 function slideDownStep1(dist){ // dist 下滑的距离,用以拉长背景模拟拉伸效果
  var slideDown1 = document.getElementById("slideDown1"),
   slideDown2 = document.getElementById("slideDown2");
  slideDown2.style.display = "none";
  slideDown1.style.display = "block";
  slideDown1.style.height = (parseInt("20px") - dist) + "px";
 }
 //第二步:下拉,然后松开,
 function slideDownStep2(){ 
  var slideDown1 = document.getElementById("slideDown1"),
   slideDown2 = document.getElementById("slideDown2");
  slideDown1.style.display = "none";
  slideDown1.style.height = "20px";
  slideDown2.style.display = "block";
  //刷新数据
  //location.reload();
 }
 //第三步:刷新完成,回归之前状态
 function slideDownStep3(){ 
  var slideDown1 = document.getElementById("slideDown1"),
   slideDown2 = document.getElementById("slideDown2");
  slideDown1.style.display = "none";
  slideDown2.style.display = "none";
 }

 //下滑刷新调用
 k_touch("content","y");
 //contentId表示对其进行事件绑定,way==>x表示水平方向的操作,y表示竖直方向的操作
 function k_touch(contentId,way){ 
  var _start = 0,
   _end = 0,
   _content = document.getElementById(contentId);
  _content.addEventListener("touchstart",touchStart,false);
  _content.addEventListener("touchmove",touchMove,false);
  _content.addEventListener("touchend",touchEnd,false);
  function touchStart(event){ 
   //var touch = event.touches[0]; //这种获取也可以,但已不推荐使用

   var touch = event.targetTouches[0];
   if(way == "x"){ 
    _start = touch.pageX;
   }else{ 
    _start = touch.pageY;
   }
  }
  function touchMove(event){ 
   var touch = event.targetTouches[0];
   if(way == "x"){ 
    _end = (_start - touch.pageX);
   }else{ 
    _end = (_start - touch.pageY);
    //下滑才执行操作
    if(_end < 0){
     slideDownStep1(_end);
    }
   }

  }
  function touchEnd(event){ 
   if(_end >0){ 
    console.log("左滑或上滑 "+_end);
   }else{ 
    console.log("右滑或下滑"+_end);
    slideDownStep2();
    //刷新成功则
    //模拟刷新成功进入第三步
    setTimeout(function(){ 
     slideDownStep3();
    },2500);
   }
  }
 }
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
日历查询的算法 如何计算某一天是星期几
Dec 12 Javascript
js下拉框二级关联菜单效果代码具体实现
Aug 03 Javascript
jquery属性选择器not has怎么写 行悬停高亮显示
Nov 13 Javascript
JS的encodeURI和java的URLDecoder.decode使用介绍
May 08 Javascript
js实现全国省份城市级联下拉菜单效果代码
Sep 07 Javascript
Node+Express+MongoDB实现登录注册功能实例
Apr 23 Javascript
jquery radio 动态控制选中失效问题的解决方法
Feb 28 jQuery
基于IView中on-change属性的使用详解
Mar 15 Javascript
微信公众平台 客服接口发消息的实现代码(Java接口开发)
Apr 17 Javascript
微信小程序如何调用json数据接口并解析
Jun 29 Javascript
vue 实现强制类型转换 数字类型转为字符串
Nov 07 Javascript
javascript json对象小技巧之键名作为变量用法分析
Nov 11 Javascript
前端js实现文件的断点续传 后端PHP文件接收
Oct 14 #Javascript
js关于getImageData跨域问题的解决方法
Oct 14 #Javascript
AngularJS 与Bootstrap实现表格分页实例代码
Oct 14 #Javascript
深入学习js瀑布流布局
Oct 14 #Javascript
微信小程序 地图定位简单实例
Oct 14 #Javascript
Bootstrap作品展示站点实战项目2
Oct 14 #Javascript
JS控制页面跳转时未请求要跳转的地址怎么回事
Oct 14 #Javascript
You might like
php daodb插入、更新与删除数据
2009/03/19 PHP
php 中英文语言转换类代码
2011/08/11 PHP
如何通过View::first使用Laravel Blade的动态模板详解
2017/09/21 PHP
window.returnValue使用方法示例介绍
2014/07/03 Javascript
JavaScript中的Web worker多线程API研究
2014/12/06 Javascript
javascript实现点击商品列表checkbox实时统计金额的方法
2015/05/15 Javascript
10条建议帮助你创建更好的jQuery插件
2015/05/18 Javascript
Javascript中arguments对象的详解与使用方法
2016/10/04 Javascript
JS实现的简单拖拽功能示例
2017/03/13 Javascript
ES6新特性之字符串的扩展实例分析
2017/04/01 Javascript
Angular中的$watch方法详解
2017/09/18 Javascript
通过源码分析Vue的双向数据绑定详解
2017/09/24 Javascript
JS中使用textPath实现线条上的文字
2017/12/25 Javascript
详解如何在vue项目中使用layui框架及采坑
2019/05/05 Javascript
JavaScript字符串处理常见操作方法小结
2019/11/15 Javascript
使用Python判断IP地址合法性的方法实例
2014/03/13 Python
Python with用法实例
2015/04/14 Python
Eclipse和PyDev搭建完美Python开发环境教程(Windows篇)
2016/11/16 Python
更新修改后的Python模块方法
2019/03/03 Python
详解Python中is和==的区别
2019/03/21 Python
pip安装python库的方法总结
2019/08/02 Python
Flask中endpoint的理解(小结)
2019/12/11 Python
python数据库编程 Mysql实现通讯录
2020/03/27 Python
Python字符串的15个基本操作(小结)
2021/02/03 Python
ivx平台开发之不用代码实现一个九宫格抽奖功能
2021/01/27 HTML / CSS
伦敦最著名的老字号百货公司:Selfridges(塞尔福里奇百货)
2016/07/25 全球购物
如何实现jdbc性能优化
2012/07/30 面试题
网上签名寄语活动留言
2014/01/18 职场文书
迟到检讨书大全
2014/01/25 职场文书
英语简历自我评价
2014/01/26 职场文书
应届大学生自荐书
2014/06/17 职场文书
大学生实习证明范本
2014/09/19 职场文书
“四风”问题自我剖析材料思想汇报
2014/09/23 职场文书
学习与创新自我评价
2015/03/09 职场文书
教师理论学习心得体会
2016/01/21 职场文书
总结Java对象被序列化的两种方法
2021/06/30 Java/Android