vue引入swiper插件的使用实例
程序员文章站
2023-09-08 20:27:06
本文介绍了vue引入swiper插件,分享给大家,希望对大家有帮助
步骤一:安装vue,
$ npm install vue...
本文介绍了vue引入swiper插件,分享给大家,希望对大家有帮助
步骤一:安装vue,
$ npm install vue
步骤二:创建vue项目
# 全局安装 vue-cli $ npm install -g vue-cli $ cd my-project $ npm install $ npm run dev
上面这些就是安装好vue项目,最主要的就是下面的步骤
步骤三:下载好swiper相关的js和css,js放在static目录下,css放在assets目录下。
步骤四:
安装runtime:
终端命令:npm install babel-runtime
步骤五:
修改.eslintrc.js文件如下:
// http://eslint.org/docs/user-guide/configuring module.exports = { root: true, parser: 'babel-eslint', parseroptions: { sourcetype: 'module' }, env: { browser: true, }, // https://github.com/feross/standard/blob/master/rules.md#javascript-standard-style extends: 'standard', // required to lint *.vue files plugins: [ 'html' ], // add your custom rules here 'rules': { // allow paren-less arrow functions 'arrow-parens': 0, // allow async-await 'generator-star-spacing': 0, // allow debugger during development 'no-debugger': process.env.node_env === 'production' ? 2 : 0 }, 'globals': { "swiper": true } //这个地方是新加入的 全局注入 }
步骤六:在自己的vue文件中添加轮播图代码
<div v-on:mouseenter="stopplay()" v-on:mouseleave="play()" class="swiper-container gallery-top swiper-container-horizontal"> <div class="swiper-wrapper"> <div v-for="value in lbt" class="swiper-slide swiper-slide-next" style="width: 100%; margin-right: 10px;" v-bind:style="{backgroundimage: 'url(' + value.imgs + ')'}"></div> </div> <div class="swiper-button-next swiper-button-white"></div> <div class="swiper-button-prev swiper-button-white swiper-button-disabled"></div> </div> <div class="swiper-container gallery-thumbs swiper-container-horizontal"> <div class="swiper-wrapper"> <div v-for="value in lbt" class="swiper-slide swiper-slide-next" style="margin-right: 10px;" v-bind:style="{backgroundimage: 'url(' + value.imgs + ')'}"></div> </div> </div>
import swiper from '../../static/swiper-3.4.2.min.js' let gallerytop let gallerythumbs export default { name: 'main', data () { return { lbt: [ { 'imgs': '../static/product/lbt1.jpg' }, { 'imgs': '../static/product/lbt2.jpg' }, { 'imgs': '../static/product/lbt3.jpg' } ] } }, mounted () { this.lunbo() }, methods: { lunbo () { gallerytop = new swiper('.gallery-top', { nextbutton: '.swiper-button-next', prevbutton: '.swiper-button-prev', spacebetween: 10, grabcursor: true, initialslide: 1, autoplaydisableoninteraction: false }) gallerythumbs = new swiper('.gallery-thumbs', { spacebetween: 10, autoplay: 4000, initialslide: 1, centeredslides: true, slidesperview: 'auto', touchratio: 0.2, slidetoclickedslide: true, autoplaydisableoninteraction: false, grabcursor: true }) gallerytop.params.control = gallerythumbs gallerythumbs.params.control = gallerytop }, stopplay () { gallerytop.stopautoplay() gallerythumbs.stopautoplay() }, play () { gallerytop.startautoplay() gallerythumbs.startautoplay() } } }
@import url("../assets/swiper-3.4.2.min.css"); .gallery-top{ height:32rem; width:100%; } .gallery-thumbs{ height:20%; box-sizing:border-box; padding:10px 0; background: rgba(0, 0, 0, 0.4); cursor: pointer; } .gallery-thumbs .swiper-slide{ width:30%; height:6rem; opacity:0.3; } .gallery-thumbs .swiper-slide-active{ opacity:1; } .swiper-slide{ background-size: 100% 160%; -webkit-background-size: 100% 160%; }
这里还有一个很重要的问题,在模板里面设置背景图,写法应该是
v-bind:style="{backgroundimage: 'url(' + value.imgs + ')'}"
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 详解vue-cli + webpack 多页面实例配置优化方法
下一篇: js编写简单的计时器功能
推荐阅读
-
vue-cli项目中使用公用的提示弹层tips或加载loading组件实例详解
-
Vue项目在HTML中使用Animate.cssdonghu动画库的实例讲解
-
解决Vue使用swiper动态加载数据,动态轮播数据显示白屏的问题
-
Vue引用Swiper4插件无法重写分页器样式的解决方法
-
vue使用websocket的方法实例分析
-
解决Vue中引入swiper,在数据渲染的时候,发生不滑动的问题
-
vue-cli+webpack在生成的项目中使用bootstrap实例代码
-
vue-lazyload图片延迟加载插件的实例讲解
-
使用Vue.observable()进行状态管理的实例代码详解
-
在Vue项目中使用d3.js的实例代码