一、安装swiper插件
npm i swiper@5
二、main.js引入swiper样式
import "swiper/css/swiper.css"
三、src/components/Swiper.vue创建公共组件
<template>
<!--banner轮播-->
<div class="swiper-container" ref="cur">
<div class="swiper-wrapper">
<div class="swiper-slide" v-for="(carousel) in carouselList" :key="carousel.id">
<img class="imgSzie" :src="carousel.img_url" />
</div>
</div>
<!-- 如果需要分页器 -->
<div class="swiper-pagination"></div>
<!-- 如果需要导航按钮 -->
<div class="swiper-button-prev btnSize"></div>
<div class="swiper-button-next btnSize"></div>
</div>
</template>
<script>
import Swiper from "swiper";
export default {
name: "mySwiper",
props: ["carouselList"],
watch: {
carouselList: {
immediate: true,
deep:false,
handler() {
this.$nextTick(() => {
var mySwiper = new Swiper(this.$refs.cur,{
loop: true,
pagination: {
el: ".swiper-pagination",
clickable: true
},
navigation: {
nextEl: ".swiper-button-next",
prevEl: ".swiper-button-prev"
}
});
});
}
}
}
};
</script>
<style scoped>
.imgSzie{
width: 100%;
}
.btnSize{
font-size: 12px;
}
</style>>
四、main.js中注册为全局组件
import Swiper from '@/components/Swiper'
Vue.component('Swiper',Swiper)
五、其他组件中使用
<Swiper :carouselList="adList"></Swiper>