日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

android下拉刷新动画效果代码_vue项目实录:下拉刷新组件的开发及slot的使用

發布時間:2025/5/22 vue 59 豆豆
生活随笔 收集整理的這篇文章主要介紹了 android下拉刷新动画效果代码_vue项目实录:下拉刷新组件的开发及slot的使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

“下拉刷新”和“上滑加載更多”功能在前端、尤其是移動端項目中非常重要,這里筆者由曾經做過的vue項目中的“blink”功能和各位探討下【下拉刷新】組件的開發:

JavaScript正式開篇

在前端項目的 components 文件夾下新建 pullRefreshView 文件夾,在其中新建組件 index.vue:(它代表“整個屏幕”,通過slot插入頁面其他內容而不是傳統的設置遮罩層觸發下拉刷新)

首先需要編寫下拉刷新組件的 template,這里用到 <slot>,代碼如下:

<template><div class="pullRefreshView" @touchmove="touchmove" @touchstart="touchstart" @touchend="touchend"><div ref="circleIcon" class="circle-icon"><div ref="circleIconInner" class="circle-icon-inner"></div></div><slot></slot></div> </template>

上面代碼中,最外層使用了一個 div 用來包裹,作為事件綁定的容器,同時新建一個圓形 icon 的 div .circleIcon,我們將此 icon 樣式設置在屏幕外,達到隱藏的效果,代碼如下:

<style>.circle-icon{position: absolute;left: 0.625rem;top: -1.875rem;}.circle-icon-inner{width: 1.5625rem;height: 1.5625rem;background-image: url('圓圈圖片地址');background-size: cover;}.circle-rotate{animation: xuzhuan .8s linear infinite;}@keyframes xuzhuan{0%{}25%{}50%{}75%{}100%{}} </style>

下拉刷新組件的 UI 基本編寫完畢,接下來就要綁定事件了,通過上述分析,加上我們之前章節開發圖片查看器的原理,我們需要用到移動端 touchstart,touchmove,touchend 事件,可以實現下拉刷新效果。

首先,監聽 touchstart 事件:

touchstart(evt){this.pullRefresh.dragStart=evt.targetTouches[0].clientYthis.$refs.circleIcon.style.webkitTransition='none' },

在 touchstart 事件中,我們主要做的是記錄一些初始值,包括手指第一次接觸屏幕時的位置,然后將圓形 icon 的動畫效果先隱藏。

然后,監聽 touchmove 事件:

touchmove(evt){if(this.pullRefresh.dragStart===null){return}let target=evt.targetTouches[0]// 向上滑為正,向下拉為負this.pullRefresh.percentage=(this.pullRefresh.dragStart-target.clientY)/window.screen.heightlet scrollTop=document.documentElement.scrollTop || document.body.scrollTopif(scrollTop===0){//this.pullRefresh指data中的pullRefresh對象(下方有),而evt即事件event參數if(this.pullRefresh.percentage<0 && evt.cancelable){evt.preventDefault()this.pullRefresh.joinRefreshFlag=truelet translateY=-this.pullRefresh.percentage*this.pullRefresh.moveCountif(Math.abs(this.pullRefresh.percentage)<=this.pullRefresh.dragThreshold){let rotate=translateY/30*360this.$refs.circleIcon.style.webkitTransform='translate3d(0'+translateY+'px,0) rotate('+rotate+'deg)'}}else{if(this.pullRefresh.joinRefreshFlag===null){this.pullRefresh.joinRefreshFlag=false}}}else{if(this.pullRefresh.joinRefreshFlag===null){this.pullRefresh.joinRefreshFlag=false}} },

在 touchmove 事件里,我們主要做的是根據手指移動的量來實時將圓形 icon 移動并旋轉,這里有幾點確實要說明一下:

  • 我們的下拉刷新觸發的時機是在頁面處于屏幕頂部并且手指向下拖動,這兩個條件,缺一不可,在代碼中,我們利用 scrollTop == 0和this.pullRefresh.percentage < 0 來判斷。
  • 在進入下拉刷新狀態時,此時手指不斷向下拖動,首先圓形 icon.circleIcon 會向下滾動并旋轉,當滾動到臨界值時就只原地旋轉。
  • 如果手指在向上拖動,圓形 icon.circleIcon 就會向上滾動并旋轉。
  • 直到手指離開屏幕前,都不會觸發下拉刷新,只是圓形 icon.circleIcon 在不停的上下移動。

監聽 touchend 事件:

touchend(evt){if(this.pullRefresh.percentage===0){return}if(Math.abs(this.pullRefresh.percentage)>this.pullRefresh.dragThreshold && this.pullRefresh.joinRefreshFlag){this.$emit('onRefresh')this.$refs.circleIconInner.classList.add('circle-rotate')setTimeout(()=>{this.$refs.circleIconInner.classList.remove('circle-rotate')this.$refs.circleIcon.style.webkitTransition='330ms'this.$refs.circleIcon.style.webkitTransform='translate3d(0,0,0) rotate(0deg)'},700)}else{if(this.pullRefresh.joinRefreshFlag){this.$refs.circleIcon.style.webkitTransition='330ms'this.$refs.circleIcon.style.webkitTransform='translate3d(0,0,0) rotate(0deg)'}}this.pullRefresh.joinRefreshFlag=nullthis.pullRefresh.dragStart=nullthis.pullRefresh.percentage=0 }

在 touchend 事件中,我們主要是做一些動畫執行的操作,大家可以看看代碼中的注釋,這里說明一下:

  • 此時手指離開屏幕,位移量達到臨界值時,并且也有進入下拉刷新的標志位,就表明要觸發正在刷新。此時圓形 icon原地旋轉,并觸發下拉刷新回調方法,延遲 700ms 后向上收起。
  • 我們在實現圓形 icon 時的旋轉和位移動畫時,用了兩個 div,在 touchmove 時,我們主要對外層的 div 也就是 ref=circleIcon,來實現位移和旋轉。
  • 在 touchend 時,我們主要給內層的 div 也就是 ref=circleIconInner 來加 animation 動畫,因為無法給一個 div 同時使用位移旋轉和 animation 動畫,所以這里一個技巧就是給父元素設置位移和旋轉,它的子元素在不設置任何 CSS 動畫樣式時,是會隨著父元素而生效的。
  • 最后,我們看下【data】中都有什么:

    data(){return{pullRefresh:{dragStart:null, //開始抓取標志位percentage:0, //拖動量(百分比)dragThreshold:0.3, //臨界值moveCount:200, //位移系數,可以調節圓形圖片icon的運動速率joinRefreshFlag:null, //進入刷新狀態的標志位(true)}} },

    補充:slot

    <template>中為什么有<slot>?

    slot有三種形式:

  • 普通插槽
  • 具名插槽
  • 作用域插槽
  • 可能我們一般用具名slot的時候比較多,但是第一種也格外好用——正因為它沒有名字,所以引用這個組件的另一個組件中包裹其中的所有內容都歸這個slot所有:

    假定my-component組件中有如下模板:

    <div><h2>我是子組件</h2><slot>只有在沒有內容分發的情況下這句話才會出現</slot> </div>

    父組件模板:

    <div><h1>這是父組件地盤</h1><my-component><p>這是一些初始內容</p><p>這是更多的內容</p></my-component> </div>

    最后就會被渲染成這樣:

    <div> <h1>這是父組件地盤</h1><div> <h2>我是子組件</h2><p>這是一些初始內容</p><p>這是更多的內容</p></div> </div>

    所以這里這樣做,就是為了在“父組件”中調用時讓“下拉的動畫”更自然,但又不會增加一個文件的負擔。

    ————————————————

    版權聲明:本文為CSDN博主「行舟客」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。

    原文鏈接:

    vue項目實錄:下拉刷新組件的開發及slot的使用_flying meng的菜鳥居-CSDN博客?blog.csdn.net

    總結

    以上是生活随笔為你收集整理的android下拉刷新动画效果代码_vue项目实录:下拉刷新组件的开发及slot的使用的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 久久久久久国产精品三区 | 亚洲作爱网 | av在线播放器 | 草草影院在线观看 | 古代黄色一级片 | 激情六月色 | 午夜激情导航 | 日本后进式猛烈xx00动态图 | 99热6这里只有精品 三级av在线免费观看 | 看片地址| 久草三级| 国产呦系列 | 视频精品一区 | 国产传媒中文字幕 | 久射久| 日本aa大片| 日韩在线欧美 | 久久99网站 | 综合伊人av | 国产精品伦一区二区三级视频 | 亚洲狼人伊人 | 久久亚洲精品无码va白人极品 | 狠狠操一区 | 99爱这里只有精品 | 欧美日韩亚洲精品一区二区 | 精品人人人人 | 妺妺窝人体色www在线小说 | 美日韩精品视频 | av图区 | 亚洲精品午夜精品 | 美女一二三区 | 亚洲永久免费观看 | 超碰人人超碰 | 中文字幕在线高清 | a在线观看视频 | 亚洲国产精品久久久久爰性色 | 修仙淫交(高h)h文 | 精品一区在线视频 | 国产尤物网站 | а天堂中文在线官网 | 精品视频在线观看一区 | mm131亚洲精品 | 91爱啪啪 | 免费一级淫片 | 亚洲欧美中文日韩在线 | 五月激情片 | 91淫黄大片 | 91亚洲精华国产精华精华液 | 69欧美视频 | 亚洲综合图片网 | 污视频在线播放 | 中文字幕亚洲在线 | 一区二区三区久久久久 | 伊人久久久久久久久久久久 | 亚洲精品人妻无码 | 免费日本黄色 | 毛片的网站 | 姑娘第5集在线观看免费好剧 | 日韩在线国产精品 | 国产亚洲精品精品精品 | 日本在线www | 中国老太婆性做爰 | 黄色av一级片 | 青草久久久 | jizz免费视频| 日本不卡一区二区 | www三级 | 国产又爽又黄又嫩又猛又粗 | 黄色成人免费观看 | 日韩欧美大片在线观看 | 少妇专区| 久久婷婷热 | 国产成人无码一区二区三区在线 | 在线1区| 成年人视频在线免费看 | 在线视频欧美日韩 | 一级伦理片 | 亚洲图片在线视频 | 五月婷六月| 91成人网页 | 亚欧中文字幕 | 成人h在线| 国产成人精品一区二区在线小狼 | 日本熟妇一区二区 | 韩国午夜激情 | 欧美成人精品欧美一 | 国产精品成人一区二区网站软件 | 天天干,天天爽 | 久久国产精品波多野结衣 | 欧美伦乱 | 免费观看久久 | 日本一区中文字幕 | 日韩不卡av | 男女黄色又爽大片 | 中国免费黄色片 | 亚洲性av| 青青草精品在线视频 | 拍国产真实乱人偷精品 | 亚洲色图28p |