1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > vue移动端实现下拉刷新步骤详解

vue移动端实现下拉刷新步骤详解

时间:2022-12-01 22:13:17

相关推荐

vue移动端实现下拉刷新步骤详解

web前端|js教程

步骤,刷新,下拉

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

微商城o2o 源码,ubuntu添加账户密码,tomcat显示摧毁处理器,用爬虫爬,小程序消息推送php,seo营销主要lzw

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

输入法源码,vscode里面没有新建文件,上网本ubuntu,Tomcat网页跳转不了,sqlite修改信息,运动网页设计图片,服务器优化方式,auto登陆插件,前端框架oneui,爬虫网络搜,php oop思想,seo的发展前景怎么样,深度调优springboot,网站后台管理系统 设计,会员登录注册网页模板,扁平化设计风格的网站模板免费下载,400管网后台,dede获取当前页面路径,美发店管理系统代码,如何编写麻将程序代码lzw

android slidemenu源码,vscode引入echar,ubuntu5.04安装教程,tomcat7.0.108,SQLITE空间索引MBR,jq日历范围插件,前端框架开发 招聘,Python网页爬虫系统,php中的对象,seo cpa,优客逸家 网站源码,网页迷宫游戏代码,那个网站的织梦模板多,php 获取页面的title,售后管理系统 开源系统,长微博程序lzw

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

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

接入正题!!!

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

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

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

大体思路:

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

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

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

3.启动下拉刷新事件

看代码:

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

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

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 = falseif(this.state === 2) {this.top = 40return }// 判断抬起时的高度,是大于40 就开启刷新if(this.top >= 40) {this.refresh()} else {this.state = 0this.top = 0}},refresh() {this.state = 2this.top = 40const self = this// 这里可以调用父组件的方法去请求刷新接口this.$emit(getRefresh, function(self){//传个回调过去,请求完数据就复原self.state = 0self.top = 0})}}}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。