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

Vue中使用Swiper簡單封裝組件示例

 更新時間:2023年08月20日 16:34:51   作者:黃金原野  
這篇文章主要為大家介紹了Vue中使用Swiper簡單封裝組件示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

正文

Swiper的最簡單使用,參考官網(wǎng)教程

但通常情況下,<swiper-slide></swiper-slide>作為循環(huán)展示的內(nèi)容,需要能夠展示多種樣式的循環(huán)列表,此時必須要使用slot

需要封裝的Swiper組件命名為MySwiper.vue,代碼如下

loop表示是否循環(huán)展示,值為false時會來回切換,相當魔性
autoplay是否自動循環(huán)展示,值為false時不會自動循環(huán),delay為每頁停留的時間

需要循環(huán)的部分<swiper-slide>,其中應(yīng)當包含的內(nèi)容就是需要循環(huán)展示的自定義組件,使用slot插槽占位

在調(diào)用時,首先從父組件獲取數(shù)據(jù)showList,傳至子組件MySwiperMySwiper<swiper-slide>循環(huán)若干次,也就生成了若干的slot,在調(diào)用slot的時候,綁定名為item的attribute,在父組件中可以通過v-slot接受,參數(shù)起名為slotProps,b包含所有slot中傳輸?shù)腶ttribute,此處包含傳輸?shù)膇tem。

作用域插槽

參考vue官網(wǎng)作用域插槽

<template>
    <div class="swiper-display">
        <swiper
            :modules="modules"
            :slides-per-view="1"
            :space-between="50"
            navigation
            :pagination="{ clickable: true }"
            :scrollbar="{ draggable: true }"
            @swiper="onSwiper"
            @slideChange="onSlideChange"
            loop
            autoplay="{
              delay: 2000
            }"
        >
            <swiper-slide class="swiper-item" v-for="item in list" :key="item.seq">
                <slot :item="item"></slot>
            </swiper-slide>
        </swiper>
    </div>
</template>
<script>
import { Navigation, Pagination, Scrollbar, A11y, Autoplay } from 'swiper';
import { Swiper, SwiperSlide } from 'swiper/vue';
import { onMounted } from 'vue';
import 'swiper/css';
export default {
    components: {
      Swiper,
      SwiperSlide,
    },
    props: {
        list: Array
    },
    setup(props) {
        const onSwiper = (swiper) => {
            // console.log(swiper);
        };
        const onSlideChange = () => {
            // console.log('slide change');
        };
        return {
            onSwiper,
            onSlideChange,
            modules: [Navigation, Pagination, Scrollbar, A11y, Autoplay],
            autoPlay
        };
    },
}
</script>
<style lang="scss">
.swiper-display {
    width: 100%;
    height: 100%;
    position: relative;
    .swiper {
        height: 100%;
        .swiper-wrapper {
            height: 100%;
            .swiper-item {
                height: 100%;
            }
        }
    }
}
</style>

使用方式如下,其中ToDisplay表示需要利用Swiper展示的自定義組件

<MySwiper v-slot="slotProps" :list="showList">
  <ToDisplay :item="slotProps.item"></ToDisplay>
</MySwiper>

此外,需要注意css的設(shè)置。
<swiper-slide>中,如果直接寫html內(nèi)容,例如div之流,swiper-slide的高度可以被正常撐開。但如果寫成一個封裝組件,swiper-slide的高度會渲染為0,導(dǎo)致內(nèi)容顯示為空。

此處有兩個解決方案:

  • 設(shè)置swiper-slide的高度。雖然可以解決,但通用性較差,如果能確保所有Swiper高度相同,可以考慮。但需要注意min-height是無效的,不會隨著填充的內(nèi)容高度增加而增加,相當于是一個固定值
  • 將父元素逐個設(shè)置為100%,雖然有點傻,但能較好地適應(yīng)Swiper中內(nèi)容高度不同的情況
.swiper-display {
    width: 100%;
    height: 100%;
    position: relative;
    .swiper {
        height: 100%;
        .swiper-wrapper {
            height: 100%;
            .swiper-item {
                height: 100%;
            }
        }
    }

以上就是Vue中使用Swiper簡單封裝組件示例的詳細內(nèi)容,更多關(guān)于Vue Swiper封裝組件的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue中清除定時器的方法實例詳解

    vue中清除定時器的方法實例詳解

    很多情況下,進入和退出vue界面,都沒有清除定時器,從而導(dǎo)致有很多定時器一起工作,這樣肯定是不行的,下面這篇文章主要給大家介紹了關(guān)于vue中清除定時器的方法,需要的朋友可以參考下
    2023-02-02
  • vue控制滾動條滑到某個位置的方法實例

    vue控制滾動條滑到某個位置的方法實例

    當容器有滾動條時,有時需要將滾動條滑到某個位置,下面這篇文章主要給大家介紹了關(guān)于vue控制滾動條滑到某個位置的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-12-12
  • Vue中比較流行且好用的組件使用示例

    Vue中比較流行且好用的組件使用示例

    這篇文章主要介紹了Vue中比較流行且好用的一些組件使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • Vue3中的極致防抖/節(jié)流詳解(附常見方式防抖/節(jié)流)

    Vue3中的極致防抖/節(jié)流詳解(附常見方式防抖/節(jié)流)

    在JavaScript中函數(shù)的防抖和節(jié)流不是什么新鮮話題,這篇文章主要給大家介紹了關(guān)于Vue3中極致防抖/節(jié)流的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • vue-virtual-scroll-list虛擬組件實現(xiàn)思路詳解

    vue-virtual-scroll-list虛擬組件實現(xiàn)思路詳解

    這篇文章主要給大家介紹了關(guān)于vue-virtual-scroll-list虛擬組件實現(xiàn)思路的相關(guān)資料,文中通過實例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2023-02-02
  • 使用vue-cli初始化項目時運行‘npm run dev’報錯及解決

    使用vue-cli初始化項目時運行‘npm run dev’報錯及解決

    這篇文章主要介紹了使用vue-cli初始化項目時運行‘npm run dev’報錯及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • 如何在vue中使用ant-design-vue組件

    如何在vue中使用ant-design-vue組件

    這篇文章主要介紹了如何在vue中使用ant-design-vue組件,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • Vue使用v-model收集各種表單數(shù)據(jù)、過濾器的示例詳解

    Vue使用v-model收集各種表單數(shù)據(jù)、過濾器的示例詳解

    這篇文章主要介紹了Vue使用v-model收集各種表單數(shù)據(jù)、過濾器的示例,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • iview給radio按鈕組件加點擊事件的實例

    iview給radio按鈕組件加點擊事件的實例

    下面小編就為大家?guī)硪黄猧view給radio按鈕組件加點擊事件的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • vueScroll實現(xiàn)移動端下拉刷新、上拉加載

    vueScroll實現(xiàn)移動端下拉刷新、上拉加載

    這篇文章主要介紹了vueScroll實現(xiàn)移動端下拉刷新、上拉加載,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03

最新評論