详解vue移动端 下拉刷新 - 绯色璃

feiseli 2021-12-19 原文


详解vue移动端 下拉刷新


看完这篇文章,相信大伙也一样可以,做出一个自己的刷新,加载的组件

说这个功能之前,大家要先了解一下,要怎么触发滚动条事件。

       一定要注意,所有滚动事件都必须要满足这个条件,横向滚动条也一样,

只要满足子元素宽度大于父元素宽度就可以了。(下篇文章会讲怎么实现一个横向滚动条)

      接入正题!!!

先来看看怎么剖析这个下拉刷新。

要用到的移动端的三个事件: touchstart(手指按下),touchmove(手指移动),touchend(手指离开)

下拉刷新也就是(touchstart => touchmove(下移动) =>touchend)的一个过程

大体思路

       下拉主要与手指触摸y轴点有关

       1.记录下手指按下y轴的坐标点

       2.记录手指移动时,移动的距离(注意:要判断手指是向上移还是向下移,向上移就是滚动)

       3.启动下拉刷新事件

看代码:

  vue中要在methods里面注册事件,在绑定到父元素上,这里大家应该都是用vue-cli搭建的项目了吧!

没有的话,我回头给个链接给大家,里面有已经搭建好的项目结构。包含这个插件的源码,demo都在里面1

<template>
  <div class="parent">
    <div class="child"></div>
  </div>
</template>
<script>
export default {
  data(){
    return {
      top: 0,
      startY: 0, // 保存 y轴点的位置
      touching: false, // 代表当前是否处于 下拉刷新行为的开关,也就是当属于滚动行为时,就要退出该事件机制
    }  
  },
  methods: {
    touchStart(e) {
      // e代表该事件对象,
e.targetTouches[0].pageY可以拿到手指按下的 y轴点
      this.startY = e.targetTouches[0].pageY
      // 开启下拉刷新状态
      this.touching = true
      
    },
    touchMove(e) {
     //这个 touchMove,只要页面在动都会发生的,所以 touching就起作用了
      // 如果 touching为false,说明这个正在移动的页面不是我们想要的下拉刷新,有可能是用户随意拉了一下页面而已,或者其他
      if(!this.touching) return
      // 获取移动的距离
      let diff = e.targetToc=uches[0].pageY - this.startY
      //判断是向上拉还是向下拉
      if(diff >0) {
        e.preventDefault()
      } else {
        return   
      }
      //这个this.top要对应绑定到该元素的transform: translateY(+top+ \'px\')上,不然是无法拉动的
      // 因此这里还要对偏移高度做一下处理,直接设置diff +
(this.state === 2 ? 40 : 0) 太快了,因为拉取幅度太大
      // 让diff*0.25这样子就差不多了
       this.top =
Math.floor(diff*0.25) + (this.state === 2 ? 40 : 0)
      if(this.top >= 40){
        this.state = 1 //代表正在拉取
      } else {
        this.state = 0 // 代表初始转态
      }
   
    },
    touchEnd(e) {
      this.touching = false
      if(this.state === 2) {
        this.top = 40
        return
      }
      // 判断抬起时的高度,是大于40 就开启刷新
      if(this.top >= 40) {
        this.refresh()
      } else {
        this.state = 0
        this.top = 0
      }
    },
    refresh() {
      this.state = 2
      this.top = 40
      const self = this
      // 这里可以调用父组件的方法去请求刷新接口
      this.$emit(\'getRefresh\', function(self){
        //传个回调过去,请求完数据就复原
        self.state = 0
        self.top = 0
      })
    }
  }

}
</script>

 

       

到这里就完结了,当然现在肯定不能直接用的,要结合你的实际业务逻辑来用的,

我把demo放到github上了 :

https://github.com/13725102796/css3-demo/blob/master/src/plugins/scroll/scroll.vue

看不懂的,建议整个项目拉下拉,跑一下,里面还有检验的插件,弹窗的等等,都是我在项目中用到,再抽出来的。

方法: git clone https://github.com/13725102796/css3-demo.git

 

同时,也欢迎各位提提 issues,或者各位想扩展一些其它的插件都可以。

最后,别忘了给个star!与君互勉,一起啃砖!

下一篇就讲怎么做这个滚动加载!!!

 

 

 

       

posted on
2018-04-22 12:34 
绯色璃 
阅读(17061
评论(2
编辑 
收藏 
举报

 

版权声明:本文为feiseli原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/feiseli/p/8903880.html

详解vue移动端 下拉刷新 - 绯色璃的更多相关文章

  1. 市场分析常用模型 – 许愿瓶666666

    市场分析常用模型 一、宏观环境分析 1、PEST分析——从外部宏观角度分析。PEST 为一种企业所处宏观环境分 […]...

  2. 对研发团队里技术分享的一些思考 – IT界的单纯小白

    对研发团队里技术分享的一些思考   这是我最近看到的一篇关于公司技术分享的比较好的文章  就粘过来大家一起学习 […]...

  3. 回调函数(callback)经典解答 – 夜雨梧桐

    回调函数(callback)经典解答 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。作者 […]...

  4. 如何学好3D游戏引擎编程(转载) – 风恋残雪

    如何学好3D游戏引擎编程(转载) 2011-02-16 11:54  风恋残雪  阅读(5511)  评论(5 […]...

  5. 图像处理之小波变换 – Maddock

    图像处理之小波变换 Matlab 小波变换 lean图像的行列应该满足2的幂次方 img  =  imread […]...

  6. SQL Server Connection Pool基础 – 中道学友

    SQL Server Connection Pool基础 连接到数据库一般情况下是比较耗费时间的, 因为这个过 […]...

  7. python爬虫实战——5分钟做个图片自动下载器 – 狙击手+

    python爬虫实战——5分钟做个图片自动下载器 小工程   python爬虫实战——图片自动下载器   制作 […]...

  8. Linux的MySQL安装方法 – 也有理想

    Linux的MySQL安装方法 第一种:     APT方式安装       在ubuntu系统的apt软件仓 […]...

随机推荐

  1. SpringBoot集成netty实现客户端服务端交互

    看了好几天的netty实战,慢慢摸索,虽然还没有摸着很多门道,但今天还是把之前想加入到项目里的 一些想法实现了 […]...

  2. 什么是性能测试(二)

    《零成本web性能测试》第一章性能测试基础总结和自己的理解   一、性能测试概念  百度词条定义:性能测试是通 […]...

  3. flowable BPMN组件汉化

    项目需求需要用到flowable流程引擎,研究了一下,在组件汉化的时候遇到了些问题1.在网上下载了所需要的汉化 […]...

  4. 分布式事务(2)—TCC理论

    分布式事务(2)—TCC理论 上篇讲过有关2PC和3PC理论知识,博客:分布式事务(1)̵ […]...

  5. Springboot 系列(十二)使用 Mybatis 集成 pagehelper 分页插件和 mapper 插件

    点赞再看,动力无限。Hello world : ) 微信搜「 程序猿阿朗 」。 本文 Github.com/n […]...

  6. 性能测试-13.测试指标的判定标准总结

          1、页面加载时间  从页面开始加载到页面onload事件触发的时间。一般来说onload触发代表着 […]...

  7. 九种常见的数据分析模型

    1. 漏斗分析模型 漏斗分析是一套流程式数据分析,它能够科学反映用户行为状态以及从起点到终点各阶段用户转化率情 […]...

  8. 没想到,这么简单的线程池用法,深藏这么多坑!

    又又又踩坑了 生产有个对账系统,每天需要从渠道端下载对账文件,然后开始日终对账。这个系统已经运行了很久,前两天 […]...

展开目录

目录导航