首页 > 其他分享 >vue2 使用 swiper 轮播图效果

vue2 使用 swiper 轮播图效果

时间:2023-04-11 11:11:19浏览次数:65  
标签:轮播 com Swiper vue2 import true swiper

vue2 使用 swiper 轮播图效果

Posted on 2021-04-08 13:58  书中枫叶  阅读(1612)  评论(0)  编辑  收藏  举报 上次更新: 2022-03-08 17:06

第一步、先安装swiper插件

npm install swiper@3.4.1 --save-dev

第二步、组件内引入swiper插件

import Swiper from 'swiper'
import 'swiper/dist/css/swiper.min.css'

第三步、创建模板

复制代码
<template>
    <div class="swiper-container">
        <div class="swiper-container">
            <div class="swiper-wrapper">
                <div class="swiper-slide" v-for="item in 16">
                    <el-image
                            style="width: 100%; height: 100%"
                            :src="url"
                            :preview-src-list="srcList"
                            fit="fill">
                    </el-image>
                </div>
            </div>
        </div>
        <!--  导航按钮 -->
        <div class="swiper-button-prev btn swiper-button-black"></div>
        <div class="swiper-button-next btn swiper-button-black"></div>
    </div>
</template>
复制代码

第四步、mounted里面创建swiper实例就大功告成

mounted () {
   this.swiper= new Swiper('.swiper-container', {
        //轮播图swiper相关属性
      })
  }

最后附上完整代码

复制代码
<template>
    <div class="swiper-container">
        <div class="swiper-container">
            <div class="swiper-wrapper">
                <div class="swiper-slide" v-for="item in 16">
                    <el-image
                            style="width: 100%; height: 100%"
                            :src="url"
                            :preview-src-list="srcList"
                            fit="fill">
                    </el-image>
                </div>
            </div>
        </div>
        <!--  如果需要分页器 -->
     <!-- <div class="swiper-pagination"></div>-->
        <!--  导航按钮 -->
        <div class="swiper-button-prev btn swiper-button-black"></div>
        <div class="swiper-button-next btn swiper-button-black"></div>
    </div>
</template>
<script>
    import Swiper from 'swiper'
    import 'swiper/dist/css/swiper.min.css'
    export default {
        //轮播图
        name:'swiper',
        data () {
            return {
                swiper: null,
                url: 'https://fuss10.elemecdn.com/8/27/f01c15bb73e1ef3793e64e6b7bbccjpeg.jpeg',
                srcList: [
                    'https://fuss10.elemecdn.com/8/27/f01c15bb73e1ef3793e64e6b7bbccjpeg.jpeg',
                    'https://fuss10.elemecdn.com/1/8e/aeffeb4de74e2fde4bd74fc7b4486jpeg.jpeg'
                ]
            }
        },
        mounted () {
            this.swiper= new Swiper('.swiper-container', {
                //速度
                speed:2500,
                //自动播放设置
                autoplay: {
                    delay: 500,
                    disableOnInteraction: false,
                    waitForTransition: false,
                },
                // //轮播类型
                // effect : 'coverflow',
                // centeredSlides: true,
                // //轮播类型的属性设置
                // coverflowEffect: {
                //     rotate: 90,
                //     stretch: 10,
                //     depth: 90,
                //     modifier: 2,
                //     slideShadows: true
                // },
                //前进和后退的按钮
                prevButton: '.swiper-button-prev',
                nextButton: '.swiper-button-next',
                centerInsufficientSlides: true,
                //循环播放
                // loop: true,                // slidesPerGroup: 3,
                //居中显示
                loopFillGroupWithBlank: true,
                //展示张数
                slidesPerView: 'auto',
            })
        },
        methods:{}
    };
</script>
<style lang="scss">
    .swiper-container {
        width: 100%;
        height: 100%;
        padding: 15px 55px!important;
        .swiper-slide {
             width: 290px;
             height: 150px;
             padding-left: 15px;
            display: flex;
            justify-content: center;
            align-items: center;
        }
    }
    .btn {
        height: 40px;
        width: 20px;
        background-size: contain;
    }
</style>
复制代码

 

本文来自博客园,作者:书中枫叶,转载请注明原文链接:https://www.cnblogs.com/zy-mg/p/14631882.html

标签:轮播,com,Swiper,vue2,import,true,swiper
From: https://www.cnblogs.com/sexintercourse/p/17305546.html

相关文章

  • vue2源码-二、对象响应式原理
    //循环对象进行一次劫持classObserver{constructor(value){this.walk()}walk(data){//重新定义属性Object.keys(data).forEach((key)=>defineReactive(data,key, data[key]))}}//属性劫持//对对象target,定义属性key,值为value//使用Object.definProperty重......
  • 关于vue2老项目的打包优化,实现首屏加载速度提升
    分析项目代码体积yarnaddwebpack-bundle-analyzer在webpack.dev.conf.js中配置constBundleAnalyzerPlugin=require('webpack-bundle-analyzer').BundleAnalyzerPluginplugins:[newBundleAnalyzerPlugin(),//代码体积分析插件......]执行yarnrundev或......
  • Vue2异步更新及nextTick原理
    vue官网中是这样描述nextTick的在下次DOM更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,可以获取更新后的DOM。在学习nextTick是如何实现之前,我们要先了解下JavaScript的执行机制JavaScript执行机制浏览器是多线程的,例如GUI渲染线程、JS引擎线程......
  • vue2源码-一、rollup环境配置
    npminit-y创建初始化package.json并修改script为"dev":"rollup-cw"安装rollup及其插件:npminstallrolluprollup-plugin-babel@babel/core@babel/preset-env--save-dev创建rollup.config.js对rollup进行配置:配置如下:importbabelfrom'rollup-plugin-bab......
  • 轮播图
    <!DOCTYPEhtml><html><head><metacharset="utf-8"><title></title><linkrel="stylesheet"href="font/iconfont.css"><linkrel="stylesheet......
  • 支持多种文件(docx、excel、pdf)预览的vue组件库,支持vue2/3。
    原文链接https://github.com/501351981/vue-office 功能特色一站式:提供docx、pdf、excel多种文档的在线预览方案,有它就够了简单:只需提供文档的src(网络地址)即可完成文档预览体验好:选择每个文档的最佳预览方案,保证用户体验和性能都达到最佳状态安装#docx文档预览组件......
  • 使用vue2从零开始搭建自己的组件库(完整版)
    前言在前端开发中,除了常用的UI组件库以外,我们还会涉及到基于公司业务,需要定制化开发一些业务组件,还有随着项目的增多,开发人员的增多,为了提高工作效率,我们就需要统一管理好已开发好的业务组件。这时候我们就需要搭建自己的组件库,因为涉及到一些公司的业务,我们只能发布到私服的npm......
  • SwipeRefreshLayout和ListView的EmptyView共存冲突的问题
    SwipeRefreshLayout是android官方的下拉刷新控件;它内部有且只能有一个子控件;当一个ListView嵌入到它内部时,就不能为ListView带一个EmptyView了;于是很自然的想到将ListView和EmptyView纳入到一个父控件中;典型的像下面这样的布局:<android.support.v4.......
  • vue全家桶进阶之路25:Vue2的停维通知
      Vue2的技术支持会持续多久?从官方发文来看,Vue2.7是当前、同时也是最后一个Vue2.x的次级版本更新。Vue2.7会以其发布日期,即2022年7月1日开始计算,提供18个月的长期技术支持(LTS:long-termsupport)。在此期间,Vue2将会提供必要的bug修复和安全修复,但不再......
  • LoadMoreListView+SwipeRefreshLayout(分页下拉)基本结构
    一切为了快速迭代importjava.util.ArrayList;importorg.json.JSONObject;importandroid.animation.ObjectAnimator;importandroid.os.Bundle;importandroid.support.v4.widget.SwipeRefreshLayout;importandroid.util.Log;importandroid.vie......