日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

vue下拉刷新組件的開發及slot的使用詳解

瀏覽:15日期:2022-10-16 18:13:48

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

正式開篇

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

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

<template><div @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>

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

到此這篇關于vue下拉刷新組件的開發及slot的使用詳解的文章就介紹到這了,更多相關vue下拉刷新組件slot使用內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
美女精品在线| 日韩一区二区在线免费| 国产精品三上| 日韩午夜高潮| 噜噜噜躁狠狠躁狠狠精品视频| 性欧美69xoxoxoxo| 国产高清一区| 日本欧洲一区二区| 综合精品一区| 国产欧美日韩影院| 久久超级碰碰| 成人在线视频免费| 老司机免费视频一区二区三区| 国产精品黄色| 精品视频高潮| 欧美中文字幕一区二区| 夜夜嗨一区二区| 亚洲毛片在线| 国产精品宾馆| 伊人网在线播放| 欧美69视频| 蜜臀久久99精品久久久久宅男| 亚洲精品一二三**| 欧美性www| 成人在线黄色| 午夜国产欧美理论在线播放| 亚洲色图国产| 国产亚洲字幕| 色网在线免费观看| 亚洲中午字幕| 国产精品超碰| 亚洲电影在线| 日韩成人精品一区二区三区| 成人国产精品久久| 尤物网精品视频| 青青草视频一区| 色综合五月天| 亚洲国产一区二区在线观看 | 国产欧美午夜| 成人国产精品一区二区网站| 九色精品91| 欧美日韩视频免费看| 丁香六月综合| 亚洲精品九九| 日韩大片在线播放| 亚洲人成网77777色在线播放| 久久亚州av| 国产亚洲综合精品| 国产伦精品一区二区三区在线播放 | 欧美成人一二区| 精品免费av在线| 性一交一乱一区二区洋洋av| 久久av日韩| 国产视频一区在线观看一区免费| 国产精品欧美大片| 亚洲激情社区| 精品久久精品| 免费看日韩精品| 成人免费一区| 午夜精品影视国产一区在线麻豆| a日韩av网址| 日韩国产欧美三级| 亚洲综合在线电影| 欧美天堂一区二区| 精品中文字幕一区二区三区av| 久久精品av麻豆的观看方式| av免费不卡国产观看| 亚洲精品亚洲人成在线观看| 国产v综合v| 欧美一级久久| 模特精品在线| av日韩中文| 国产免费久久| 天堂成人免费av电影一区| 成人日韩av| 国产亚洲高清在线观看| 欧美1级日本1级| 国产成人精选| 国产精品一区二区精品| 日韩精品一二三| 99久久激情| 欧美激情麻豆| 日韩精品第二页| 亚洲黑丝一区二区| 精品美女视频 | 久久中文欧美| 日韩毛片网站| 西西人体一区二区| 蜜桃av.网站在线观看| 国产欧美日韩免费观看| 亚洲免费黄色| 日韩另类视频| 国产精品2023| 日韩三级精品| 日韩中文欧美在线| 亚洲精品97| 久久黄色影院| 国产精品xx| 久久精品国产网站| 国产精品色在线网站| 欧美一级网站| 日韩综合一区二区| 日韩制服丝袜先锋影音| 亚洲二区免费| 色吊丝一区二区| 麻豆视频在线观看免费网站黄 | 国产精品视频一区二区三区| 欧美视频久久| 亚洲精品免费观看| 日韩在线一区二区| 久久xxxx精品视频| 樱桃成人精品视频在线播放| 91精品二区| av一区二区高清| 亚洲香蕉网站| 亚洲一级黄色| 午夜欧美精品| 不卡一区综合视频| 免费av一区| 国产一区二区中文| 亚洲午夜电影| 国产精品毛片在线| 性欧美长视频| 婷婷综合电影| 日韩高清国产一区在线| 日日夜夜免费精品| 日本久久二区| 国产亚洲精品美女久久| 国产麻豆一区二区三区| 国产精品成人国产| 精品亚洲a∨一区二区三区18| 精品久久不卡| 四虎成人av| 亚洲黄色网址| 欧美日韩一区二区综合| 欧美一级精品| 国产精品日本| 日本在线不卡视频一二三区| 国产精品亚洲欧美一级在线| 美女高潮久久久| 亚洲精品福利电影| 影音先锋国产精品| 日本亚洲欧美天堂免费| 国产日韩欧美中文在线| 麻豆久久一区二区| 肉色欧美久久久久久久免费看| 99久久九九| 亚洲免费中文| 婷婷精品久久久久久久久久不卡| 国产另类在线| 91欧美日韩| 欧美日韩激情在线一区二区三区| 美国三级日本三级久久99| 久久精品72免费观看| 精品国产亚洲一区二区三区在线 | 国产精品久久久久久久久久齐齐| 美女尤物国产一区| 久草免费在线视频| 亚洲激情中文| 欧美日韩xxxx| 色网在线免费观看| 亚洲自拍另类| 国产精品高清一区二区| 韩国久久久久久| 国产视频久久| 国产欧美一级| 欧美精品高清| 亚洲日本国产| 国产一区二区三区探花| 不卡av一区二区| 日韩高清在线不卡| 麻豆视频在线观看免费网站黄 | 亚洲免费毛片| 精品久久久网| 日韩制服丝袜先锋影音| 精品久久美女| 国产亚洲高清视频| 国产精品极品在线观看| 1024精品一区二区三区| 日本aⅴ精品一区二区三区| 动漫av一区| 亚洲欧洲一区二区天堂久久| 国产精品一区高清| av日韩中文| 亚洲人亚洲人色久| 都市激情国产精品| 亚洲人www| 日韩一区二区在线免费| 日本在线观看不卡视频| 亚洲四虎影院| 91大神在线观看线路一区| 99久久精品国产亚洲精品| 国产午夜一区| 麻豆91精品| 日本蜜桃在线观看视频| 亚欧洲精品视频在线观看| 亚洲一级少妇| 国产欧美69| 欧美日韩免费观看一区=区三区| 国产欧美亚洲一区|