美文网首页
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开发三大件|轮播图&分页器&日历

    swiper+vuex+mock实现轮播图功能 mockjs模拟数据 安装依赖包mockjs在public文件夹中...

  • vue 项目 解决Swiper轮播图分页器无法显示问题

    Vue项目中添加轮播效果,使用swiper后,分页器无法正常显示,但轮播效果和前进后退箭头以及滚动栏都是正常显示的...

  • vue-swipe轮播图

    一、安装饿了么团队开发的vue专用的轮播图插件:vue-swipenpm install vue-swipe 二、...

  • 2019-04-28

    vue 轮播图组件

  • 07-Flask之前后端分离

    一、后台服务器开发 服务器就是提供服务,提供数据的。 二、前端开发 三、前后端分离 爱鲜蜂(轮播图)示例 【...

  • 07-Flask之前后端分离

    一、后台服务器开发 服务器就是提供服务,提供数据的。 二、前端开发 三、前后端分离 爱鲜蜂(轮播图)示例 【后台人...

  • 07-Flask之前后端分离

    一、后台服务器开发 服务器就是提供服务,提供数据的。 二、前端开发 三、前后端分离 爱鲜蜂(轮播图)示例 【后台人...

  • 07-Flask之前后端分离

    一、后台服务器开发 服务器就是提供服务,提供数据的。 二、前端开发 三、前后端分离 爱鲜蜂(轮播图)示例 【后台人...

  • Flask-day07

    一、后台服务器开发 服务器就是提供服务,提供数据的。 二、前端开发 三、前后端分离 爱鲜蜂(轮播图)示例 【后台人...

  • Vue插件之vue-awesome-swiper

    vue在移动端开发项目中,使用iview轮播图carousel组件会出现无法滑动的情况解决方式:使用vue-awe...

网友评论

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

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