一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - vue.js - vue下拉刷新組件的開發及slot的使用詳解

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

2021-12-16 15:43行舟客 vue.js

這篇文章主要介紹了vue下拉刷新組件的開發及slot的使用詳解,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

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

正式開篇

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

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

?
1
2
3
4
5
6
7
8
<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 樣式設置在屏幕外,達到隱藏的效果,代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<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 事件:

?
1
2
3
4
touchstart(evt){
    this.pullRefresh.dragStart=evt.targetTouches[0].clientY
    this.$refs.circleIcon.style.webkitTransition='none'
},

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

然后,監聽 touchmove 事件:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
touchmove(evt){
    if(this.pullRefresh.dragStart===null){
        return
    }
    let target=evt.targetTouches[0]
    // 向上滑為正,向下拉為負
    this.pullRefresh.percentage=(this.pullRefresh.dragStart-target.clientY)/window.screen.height
    let scrollTop=document.documentElement.scrollTop || document.body.scrollTop
    if(scrollTop===0){
        //this.pullRefresh指data中的pullRefresh對象(下方有),而evt即事件event參數
        if(this.pullRefresh.percentage<0 && evt.cancelable){
            evt.preventDefault()
            this.pullRefresh.joinRefreshFlag=true
            let translateY=-this.pullRefresh.percentage*this.pullRefresh.moveCount
            if(Math.abs(this.pullRefresh.percentage)<=this.pullRefresh.dragThreshold){
                let rotate=translateY/30*360
                this.$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 == 0this.pullRefresh.percentage < 0 來判斷。
  • 在進入下拉刷新狀態時,此時手指不斷向下拖動,首先圓形 icon.circleIcon 會向下滾動并旋轉,當滾動到臨界值時就只原地旋轉。
  • 如果手指在向上拖動,圓形 icon.circleIcon 就會向上滾動并旋轉。
  • 直到手指離開屏幕前,都不會觸發下拉刷新,只是圓形 icon.circleIcon 在不停的上下移動。

監聽 touchend 事件:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
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=null
    this.pullRefresh.dragStart=null
    this.pullRefresh.percentage=0
}

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

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

最后,我們看下【data】中都有什么:

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

補充:slot

<template>中為什么有<slot>

slot有三種形式:

  1. 普通插槽
  2. 具名插槽
  3. 作用域插槽

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

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

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

父組件模板:

?
1
2
3
4
5
6
7
<div>
    <h1>這是父組件地盤</h1>
    <my-component>
        <p>這是一些初始內容</p>
        <p>這是更多的內容</p>
    </my-component>
</div>

最后就會被渲染成這樣:

?
1
2
3
4
5
6
7
8
<div>
    <h1>這是父組件地盤</h1>
    <div>
        <h2>我是子組件</h2>
        <p>這是一些初始內容</p>
        <p>這是更多的內容</p>
    </div>
</div>

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

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

原文鏈接:https://blog.csdn.net/qq_43624878/article/details/109252057

延伸 · 閱讀

精彩推薦
  • vue.jsVue2.x-使用防抖以及節流的示例

    Vue2.x-使用防抖以及節流的示例

    這篇文章主要介紹了Vue2.x-使用防抖以及節流的示例,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下...

    Kyara6372022-01-25
  • vue.jsVue中引入svg圖標的兩種方式

    Vue中引入svg圖標的兩種方式

    這篇文章主要給大家介紹了關于Vue中引入svg圖標的兩種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的...

    十里不故夢10222021-12-31
  • vue.jsVue項目中實現帶參跳轉功能

    Vue項目中實現帶參跳轉功能

    最近做了一個手機端系統,其中遇到了父頁面需要攜帶參數跳轉至子頁面的問題,現已解決,下面分享一下實現過程,感興趣的朋友一起看看吧...

    YiluRen丶4302022-03-03
  • vue.jsVue2.x 項目性能優化之代碼優化的實現

    Vue2.x 項目性能優化之代碼優化的實現

    這篇文章主要介紹了Vue2.x 項目性能優化之代碼優化的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋...

    優小U9632022-02-21
  • vue.js用vite搭建vue3應用的實現方法

    用vite搭建vue3應用的實現方法

    這篇文章主要介紹了用vite搭建vue3應用的實現方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下...

    Asiter7912022-01-22
  • vue.js詳解vue 表單綁定與組件

    詳解vue 表單綁定與組件

    這篇文章主要介紹了vue 表單綁定與組件的相關資料,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下...

    Latteitcjz6432022-02-12
  • vue.jsVue多選列表組件深入詳解

    Vue多選列表組件深入詳解

    這篇文章主要介紹了Vue多選列表組件深入詳解,這個是vue的基本組件,有需要的同學可以研究下...

    yukiwu6752022-01-25
  • vue.js梳理一下vue中的生命周期

    梳理一下vue中的生命周期

    看過很多人講vue的生命周期,但總是被繞的云里霧里,尤其是自學的同學,可能js的基礎也不是太牢固,聽起來更是吃力,那我就已個人之淺見,以大白話...

    CRMEB技術團隊7992021-12-22
主站蜘蛛池模板: 成人性用品 | 日韩视频在线免费 | 三级午夜宅宅伦不卡在线 | narutomanga玖辛奈本子 | 精品无码一区二区三区中文字幕 | 男人和女人全黄一级毛片 | 国产日韩欧美色视频色在线观看 | 国产v视频 | avtt在线观看| 日本色午夜 | 美国video | 精品久久香蕉国产线看观看亚洲 | 91亚洲精品第一综合不卡播放 | 日本精品欧洲www | 大学生按摩黄a级中文片 | 肥奶丰熟肥妇 | 国产欧美曰韩一区二区三区 | 国产精品污双胞胎在线观看 | 精品一区二区91 | 亚洲欧美专区精品伊人久久 | 王者荣耀瑶白色液体 | 国产欧美日韩精品一区二区三区 | 好男人在线观看免费高清2019韩剧 | 日韩欧美一区二区不卡 | 亚洲精品一区二区久久这里 | 无码毛片内射白浆视频 | 免费看一级毛片 | 国产福利在线观看永久视频 | 国产午夜精品久久久久小说 | 国产成人毛片 | 污漫日本E同人 | 母爱成瘾在线观看 | 欧美在线一 | 欧美xxxxxbb| 91亚洲精品第一综合不卡播放 | 午夜福利合集1000在线 | 摸逼网| 免费观看视频在线播放 | 亚洲AV午夜精品麻豆AV | 美女禁区视频免费观看精选 | 情欲综合网 |