美文网首页
Vue开发三大件|轮播图&分页器&日历

Vue开发三大件|轮播图&分页器&日历

作者: Confucianmen大宇 | 来源:发表于2023-01-14 13:50 被阅读0次

    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'

    相关文章

      网友评论

          本文标题:Vue开发三大件|轮播图&分页器&日历

          本文链接:https://www.haomeiwen.com/subject/xyjncdtx.html