亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue使用Swiper封裝輪播圖組件的方法詳解

 更新時間:2022年09月05日 17:10:28   作者:chyeonL  
Swiper是一個很常用的用于實現(xiàn)各種滑動效果的插件,PC端和移動端都能很好的適配。本文將利用Swiper實現(xiàn)封裝輪播圖組件,感興趣的可以了解一下

Swiper

Swiper是一個很常用的用于實現(xiàn)各種滑動效果的插件,PC端和移動端都能很好的適配。

官網(wǎng)地址:www.swiper.com.cn/

目前最新版本是Swiper7,但眾所周知最新版本通常不穩(wěn)定,所以這里使用Swiper6來封裝。

Swiper各版本區(qū)別:

為什么要封裝組件

因為網(wǎng)頁中通常不止一個地方需要用到輪播圖,所以直接將輪播圖封裝成一個共用組件,性能會更好,修改起來也可以快速找到位置。

開始封裝

1.下載安裝Swiper

 npm install Swiper@6            // @6 是指定版本號為6 的意思
 cnpm install Swiper@6
 yarn add Swiper@6

2.引入css樣式文件

import "swiper/swiper-bundle.min.css";

3.引入js文件

import Swiper from 'swiper/swiper-bundle'

4.把官網(wǎng)使用方法中的HTML結(jié)構(gòu)復(fù)制粘貼過來

官網(wǎng)使用方法

注意:

  • 下面不是官網(wǎng)使用文檔的代碼,是我改動過的!
  • 這里的頂層容器類名,不對應(yīng)的話,后面出大問題?。。?/li>

這里官網(wǎng)的使用方法上的容器類名是swiper,對應(yīng)Swiper7

但因為這里我下載的是Swiper6,所以我改成了它對應(yīng)的容器類名swiper-container。

Swiper6及其以前的版本都是對應(yīng)類名swiper-container

// 注意這里容器的類名!!
<div class="swiper-container" ref='Carousel'>       
    <div class="swiper-wrapper">
        //v-for循環(huán)生成輪播圖片
        <div class="swiper-slide" v-for="Carousel in list" :key="Carousel.id">
            <img :src="Carousel.imgUrl" />
      </div>
    </div> 

    <!-- 如果需要分頁器 -->
    <div class="swiper-pagination"></div> 

    <!-- 如果需要導(dǎo)航按鈕 --> 
    <div class="swiper-button-prev"></div> 
    <div class="swiper-button-next"></div> 

    <!-- 如果需要滾動條 --> 
    <div class="swiper-scrollbar"></div>
</div>

5.初始化Swiper

初始化時間:有圖片數(shù)據(jù)后

但是輪播圖的圖片通常都是從后臺獲取回來的,需要確定頁面有數(shù)據(jù)并且DOM結(jié)構(gòu)完全生成后,再初始化。所以最好的方法是: watch監(jiān)聽 + $nextTick

$nextTick: 將回調(diào)延遲到下次 DOM 更新循環(huán)之后執(zhí)行。在修改數(shù)據(jù)之后立即使用它,然后等待 DOM 更新。

原理:watch監(jiān)聽圖片數(shù)據(jù)的變化,$nextTick等到DOM結(jié)構(gòu)完全生成后,立即初始化

watch: {
//list是輪播圖數(shù)據(jù)
    list: {
      immediate: true,   //頁面初始化的時候就調(diào)用一次handler()
      handler() {
        this.$nextTick(() => {
          var mySwiper = new Swiper(this.$refs.Carousel, {
            direction: "horizontal", // 水平切換選項
            loop: true, // 循環(huán)模式選項

            // 如果需要分頁器
            pagination: {
              el: ".swiper-pagination",
              clickable: true,     //可點擊
              type: "bullets",     //默認(rèn)樣式 小圓點, 還可選其他形狀
            },

            // 如果需要前進后退按鈕
            navigation: {
              nextEl: ".swiper-button-next",
              prevEl: ".swiper-button-prev",
            },
          });
        });
      },
    },
  }

自定義效果

  • 上面的樣式結(jié)構(gòu)是我自定義過的,不是原本的官方使用文檔,初次使用建議先復(fù)制官網(wǎng)的看看
  • 如果不需要按鈕/分頁器/滾動欄,可以自己在HTML結(jié)構(gòu)和初始化代碼中刪減
  • 如果想要其他的滑動效果,可以看看官網(wǎng)其他示例進行選擇
  • 如果想要改變具體樣式或者配置,可以看看官方API

完整代碼

封裝的組件名叫Carousel

<template>
  <div class="swiper-container" ref='Carousel'>
    <div class="swiper-wrapper">
      <div class="swiper-slide" v-for="Carousel in list" :key="Carousel.id">
        <img :src="Carousel.imgUrl" />
      </div>
    </div>
    <!-- 如果需要分頁器 -->
    <div class="swiper-pagination"></div>

    <!-- 如果需要導(dǎo)航按鈕 -->
    <div class="swiper-button-prev"></div>
    <div class="swiper-button-next"></div>
  </div>
</template>

<script>
// 引入swiper的js
import Swiper from "swiper/swiper-bundle.js";
import "swiper/swiper-bundle.min.css";

export default {
  name: "Carousel",
  props: ["list"],
  watch: {
    list: {
      immediate: true,
      handler() {
        this.$nextTick(() => {
          var mySwiper = new Swiper(this.$refs.Carousel, {
            direction: "horizontal", // 垂直切換選項
            loop: true, // 循環(huán)模式選項

            // 如果需要分頁器
            pagination: {
              el: ".swiper-pagination",
              clickable: true,
              type: "bullets",
            },

            // 如果需要前進后退按鈕
            navigation: {
              nextEl: ".swiper-button-next",
              prevEl: ".swiper-button-prev",
            },
          });
        });
      },
    },
  },
};
</script>

<style></style>

效果展示

到此這篇關(guān)于Vue使用Swiper封裝輪播圖組件的方法詳解的文章就介紹到這了,更多相關(guān)Vue Swiper封裝輪播圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue之Element-Ui輸入框顯示與隱藏方式

    vue之Element-Ui輸入框顯示與隱藏方式

    這篇文章主要介紹了vue之Element-Ui輸入框顯示與隱藏方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 解決vuecli3中img src 的引入問題

    解決vuecli3中img src 的引入問題

    這篇文章主要介紹了解決vuecli3中img src 的引入問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • Vue js 的生命周期(看了就懂)(推薦)

    Vue js 的生命周期(看了就懂)(推薦)

    這篇文章主要介紹了Vue js生命周期,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • Vue如何使用百度地圖自定義信息窗口InfoWindow的樣式

    Vue如何使用百度地圖自定義信息窗口InfoWindow的樣式

    這篇文章主要介紹了Vue如何使用百度地圖自定義信息窗口InfoWindow的樣式問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue使用監(jiān)聽實現(xiàn)全選反選功能

    vue使用監(jiān)聽實現(xiàn)全選反選功能

    最近做的項目用到了全選全不選功能,于是我就自己動手寫了一個,基于vue使用監(jiān)聽實現(xiàn)全選反選功能,具體實例代碼大家參考下本文
    2018-07-07
  • 在Vue頁面中如何更優(yōu)雅地引入圖片詳解

    在Vue頁面中如何更優(yōu)雅地引入圖片詳解

    我們在Vue.js項目中經(jīng)常需要引用圖片,所以下面這篇文章主要介紹了關(guān)于在Vue頁面中如何更優(yōu)雅地引入圖片的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-12-12
  • 從零開始在vue-cli4配置自適應(yīng)vw布局的實現(xiàn)

    從零開始在vue-cli4配置自適應(yīng)vw布局的實現(xiàn)

    這篇文章主要介紹了從零開始在vue-cli4配置自適應(yīng)vw布局,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • vue3基礎(chǔ)知識剖析

    vue3基礎(chǔ)知識剖析

    筆者這篇文章會從vue3基礎(chǔ)的知識點開始剖析,特別是在將composition?API的時候,在代碼示例中不會一上來就使用setup語法糖,而是用早期的setup函數(shù),這樣方便于初學(xué)的小伙伴們理解跟學(xué)習(xí)
    2022-08-08
  • VUE中template的三種寫法

    VUE中template的三種寫法

    這篇文章介紹了VUE中template的三種寫法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • vue源碼之首次渲染過程詳解

    vue源碼之首次渲染過程詳解

    這篇文章主要為大家詳細(xì)介紹了vue源碼之首次渲染過程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02

最新評論