swiper+vuex+mock实现轮播图功能
mockjs模拟数据
安装依赖包mockjs
在public文件夹中准备需要的图片
在src文件夹下创建mock文件夹,创建模拟json文件
[
{
"id": "1",
"imgUrl": "/images/banner1.jpg"
},
{
"id": "2",
"imgUrl": "/images/banner2.jpg"
},
{
"id": "3",
"imgUrl": "/images/banner3.jpg"
},
{
"id": "4",
"imgUrl": "/images/banner4.jpg"
}
]
创建sever.js文件,通过Mock.mock方法模拟出数据
//先引入mockjs模块
import Mock from 'mockjs';
//把JSON数据格式引入进来[JSON数据格式根本没有对外暴露,但是可以引入]
//webpack默认对外暴露的:图片、JSON数据格式
import banner from './banner.json';
//mock数据:第一个参数请求地址 第二个参数:请求数据
Mock.mock("/mock/banner",{code:200,data:banner});//模拟首页大的轮播图的数据
在入口文件引入serve文件
//引入MockServer.js----mock数据
import "@/mock/mockServe";
获取banner轮播图数据
在api文件夹下引入axios发请求expor const reqGetBannerList=()=>axios.get('/mock/banner')
搭建vuex仓库
引入ajax请求import { reqGetBannerList } from "@/api"
actions业务逻辑将data和服务器返回数据交给mutations,mutations把服务器返回数据赋值给data,定义一个data空数组存放服务器返回数据。
import { reqGetBannerList } from "@/api"
//state仓库存储数据的地方
const state={
// 轮播图数据
bannerList:[],
}
//actions书写业务逻辑
const actions = {
},
async getBannerList({ commit }){
let result =await reqGetBannerList();
if(result.status==200){
commit("GETBANNERLIST", result.data);
}
}
}
//mutations修改state
const mutations={
GETBANNERLIST(state, bannerList) {
state.bannerList = bannerList;
},
}
//getters计算属性,简化仓库数据让组件获得数据更方便
const getters={
}
export default {
state,
mutations,
actions,
getters,
};
搭建carousel轮播图组件
引入swiper和其样式,书写框架和逻辑
<template>
<div class="swiper-container" ref="cur">
<div class="swiper-wrapper">
<div
class="swiper-slide"
v-for="(carousel, index) in list"
:key="carousel.id"
>
<img :src="carousel.imgUrl" />
</div>
</div>
<!-- 如果需要分页器 -->
<div class="swiper-pagination"></div>
<!-- 如果需要导航按钮 -->
<div class="swiper-button-prev"></div>
<div class="swiper-button-next"></div>
</div>
</template>
<script>
//引入Swiper
import Swiper from "swiper";
export default {
name: "Carsousel",
props: ["list"],
watch: {
list: {
//立即监听:不管你数据有没有变化,我上来立即监听一次
//为什么watch监听不大list:因为这个数据从来没有发生变化(数据是父亲给的,父亲给的时候就是一个对象,对象里面该有的数据都是有的)
immediate: true,
handler() {
//只能监听到数据已经有了,但是v-for动态渲染结构我们还是没有办法确定的,因此还是需要用nextTick
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>
在入口文件引入import Carsousel from "@/components/Carousel";
在父组件组件挂载完毕后调用dispatch发送请求,在computed实例用mapState方法拿到轮播图数据,调用porps把属性绑定传入组件内
Swiper7的默认容器是'.swiper',Swiper6之前是'.swiper-container'
网友评论