国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Vue 過渡實現輪播圖

zr_hebo / 2523人閱讀

摘要:過渡實現輪播圖過渡的過渡系統是內置的,在元素從中插入或移除時自動應用過渡效果。

Vue 過渡實現輪播圖 Vue 過渡

Vue 的過渡系統是內置的,在元素從 DOM 中插入或移除時自動應用過渡效果。

過渡的實現要在目標元素上使用 transition 屬性,具體實現參考Vue2 過渡

下面例子中我們用到列表過渡,可以先學習一下官方的例子

要同時渲染整個列表,比如使用 v-for,我們需要用到 組件

Vue 輪播圖

demo
我們先看這樣一個列表

這個列表要從實例(見文章末尾)中獲取了三張圖片,要使其中的圖片產生輪播,我們需要用 組件替換其中的 ul 標簽,從而實現過渡組件的功能,完整的組件 DOM 內容如下,下面分段解釋一下


對應的數據結構如下:

data: {
    slideList: [
        {
            "clickUrl": "#",
            "desc": "nhwc",
            "image": "http://dummyimage.com/1745x492/f1d65b"
        },
        {
            "clickUrl": "#",
            "desc": "hxrj",
            "image": "http://dummyimage.com/1745x492/40b7ea"
        },
        {
            "clickUrl": "#",
            "desc": "rsdh",
            "image": "http://dummyimage.com/1745x492/e3c933"
        }
    ],
    currentIndex: 0,
    timer: ""
},
    

在使用 v-for 時,應給對應的元素綁定一個 key 屬性,相當于 index 標識,在 組件中,key 是必須的,這樣一個輪播圖的 DOM 結構就完成了

接下來我們看看輪播函數的實現,再來看組件中的 li 元素

  • 上面通過 v-for 渲染了 li 列表,并在其中插入了包含可點擊跳轉的圖片,接下來看看如何實現輪播,輪播圖的樣式直接在后面給出大家 sass 代碼,父元素 ul 設置 position: relative;overflow: hidden 后,li 大小設為和父元素相同,absolute 定位固定在父元素中,要讓 li 按照順序顯示,需要用到 v-show 或 v-if 處理,通過 index 值來改變當前顯示的 li ,本例 v-show 綁定條件 index===currentIndex,用定時器改變 currentIndex 實現輪播

  • 實例中的方法:

    created() {
        //在DOM加載完成后,下個tick中開始輪播
        this.$nextTick(() => {
            this.timer = setInterval(() => {
                this.autoPlay()
            }, 4000)
        })
    },
    go() {
        this.timer = setInterval(() => {
            this.autoPlay()
        }, 4000)
    },
    stop() {
        clearInterval(this.timer)
        this.timer = null
    },
    change(index) {
        this.currentIndex = index
    },
    autoPlay() {
        this.currentIndex++
        if (this.currentIndex > this.slideList.length - 1) {
            this.currentIndex = 0
        }
    }
    

    DOM 中為每個輪播 li 元素綁定事件 @mouseenter="stop" @mouseleave="go" 事件,使輪播鼠標移入時停止,移出時再次開始。

    輪播圖現在位置指示,綁定類名 active 改變顏色,綁定 change() 方法,鼠標移到指示點時跳轉輪播圖

    
    
    
    

    sass 樣式代碼

    .carousel-wrap {
      position: relative;
      height: 453px;
      width: 100%;
      overflow: hidden;
      // 刪除
      background-color: #fff;
    }
    
    .slide-ul {
      width: 100%;
      height: 100%;
      li {
        position: absolute;
        width: 100%;
        height: 100%;
        img {
          width: 100%;
          height: 100%;
        }
      }
    }
    
    .carousel-items {
      position: absolute;
      z-index: 10;
      top: 380px;
      width: 100%;
      margin: 0 auto;
      text-align: center;
      font-size: 0;
      span {
        display: inline-block;
        height: 6px;
        width: 30px;
        margin: 0 3px;
        background-color: #b2b2b2;
        cursor: pointer;
      }
      .active {
        background-color: $btn-color;
      }
    }
    

    滑動動畫設置,知識點詳見 Vue 教程中的 過渡 css 類名

    .list-enter-to {
      transition: all 1s ease;
      transform: translateX(0);
    }
    
    .list-leave-active {
      transition: all 1s ease;
      transform: translateX(-100%)
    }
    
    .list-enter {
      transform: translateX(100%)
    }
    
    .list-leave {
      transform: translateX(0)
    }
    

    完整 Vue 實例如下

    new Vue({
        el: "#carousel",
        data: {
            slideList: [
                {
                    "clickUrl": "#",
                    "desc": "nhwc",
                    "image": "http://dummyimage.com/1745x492/f1d65b"
                },
                {
                    "clickUrl": "#",
                    "desc": "hxrj",
                    "image": "http://dummyimage.com/1745x492/40b7ea"
                },
                {
                    "clickUrl": "#",
                    "desc": "rsdh",
                    "image": "http://dummyimage.com/1745x492/e3c933"
                }
            ],
            currentIndex: 0,
            timer: ""
        },
        methods: {
            go() {
                this.timer = setInterval(() => {
                    this.autoPlay()
                }, 4000)
            },
            stop() {
                clearInterval(this.timer)
                this.timer = null
            },
            change(index) {
                this.currentIndex = index
            },
            autoPlay() {
                this.currentIndex++
                if (this.currentIndex > this.slideList.length - 1) {
                    this.currentIndex = 0
                }
            }
        },
        created() {
            this.$nextTick(() => {
                this.timer = setInterval(() => {
                    this.autoPlay()
                }, 4000)
            })
        }
    })
    

    以上就是 Vue 過渡實現的輪播圖,喜歡的話請關注,點贊,收藏~謝謝

    文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

    轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/88198.html

    相關文章

    • 原生js寫一個無縫播圖插件(支持vue)

      摘要:輪播圖插件前言寫這個插件的原因前段時間準備用加上網易云的接口,模擬網易云音樂移動端。目前主要實現了無縫輪播,自動播放,端左右按鈕點擊切換,移動端手勢滑動切換。 輪播圖插件(Broadcast.js) 前言:寫這個插件的原因 前段時間準備用vue加上網易云的nodejs接口,模擬網易云音樂移動端。因為想自己寫一遍所有的代碼以及加固自己的flex布局,所以沒有使用UI組件。在輪播圖部分,...

      MSchumi 評論0 收藏0
    • 原生js寫一個無縫播圖插件(支持vue)

      摘要:輪播圖插件前言寫這個插件的原因前段時間準備用加上網易云的接口,模擬網易云音樂移動端。目前主要實現了無縫輪播,自動播放,端左右按鈕點擊切換,移動端手勢滑動切換。 輪播圖插件(Broadcast.js) 前言:寫這個插件的原因 前段時間準備用vue加上網易云的nodejs接口,模擬網易云音樂移動端。因為想自己寫一遍所有的代碼以及加固自己的flex布局,所以沒有使用UI組件。在輪播圖部分,...

      hatlonely 評論0 收藏0
    • 原生js寫一個無縫播圖插件(支持vue)

      摘要:輪播圖插件前言寫這個插件的原因前段時間準備用加上網易云的接口,模擬網易云音樂移動端。目前主要實現了無縫輪播,自動播放,端左右按鈕點擊切換,移動端手勢滑動切換。 輪播圖插件(Broadcast.js) 前言:寫這個插件的原因 前段時間準備用vue加上網易云的nodejs接口,模擬網易云音樂移動端。因為想自己寫一遍所有的代碼以及加固自己的flex布局,所以沒有使用UI組件。在輪播圖部分,...

      褰辯話 評論0 收藏0
    • [vue組件]無縫播圖

      摘要:實現原理無縫滾動預處理為了無縫滾動,在傳進來的數組首部增加末尾元素,在尾部追加首元素看圖數據綁定視圖為當前顯示的輪播圖索引,然后只需要對進行操作,監聽的變化,一旦到達了邊界就重置,顯示出對應的圖片。 該文章請對應源碼閱讀,github源碼地址,DEMO使用地址,線上DEOM展示。 做一個vue基礎組件系列,使用vue以最簡潔的方式實現常用組件,可用于快速二次定制化開發。 (??????...

      GHOST_349178 評論0 收藏0
    • [vue組件]無縫播圖

      摘要:實現原理無縫滾動預處理為了無縫滾動,在傳進來的數組首部增加末尾元素,在尾部追加首元素看圖數據綁定視圖為當前顯示的輪播圖索引,然后只需要對進行操作,監聽的變化,一旦到達了邊界就重置,顯示出對應的圖片。 該文章請對應源碼閱讀,github源碼地址,DEMO使用地址,線上DEOM展示。 做一個vue基礎組件系列,使用vue以最簡潔的方式實現常用組件,可用于快速二次定制化開發。 (??????...

      Clect 評論0 收藏0

    發表評論

    0條評論

    zr_hebo

    |高級講師

    TA的文章

    閱讀更多
    最新活動
    閱讀需要支付1元查看
    <