从头开始开发一个vue幻灯片组件
首先新建项目vue init webpack projectName
安装依赖包npm i这些就不说了
接下来就是构建我们的swiper组件
因为我写的代码不规范, 通不过eslint的检测, 会频繁报警告, 所以不愿意看警告的可以打开\build\webpack.base.conf.js的32行到41行注释掉
接下来才开始正式的构建组件
我直接把脚手架工具\src\components\HelloWorld.vue下的HelloWorld组件修改为Swiper, 然后把ruter\router的HelloWorld都修改成Swiper
- src\router\index.js
import Vue from 'vue'
import Router from 'vue-router'
import Swiper from '@/components/Swiper'
Vue.use(Router)
export default new Router({
routes: [
{
path: '/',
name: 'Swiper',
component: Swiper
}
]
})
- \src\components\Swiper.vue
<template>
<div class="hello">
<p>测试</p>
</div>
</template>
<script>
export default {
name: 'Swiper',
data () {
return {
}
}
}
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
</style>
npm run dev之后看到这样页面就是创建成功, 可以开始
- swiper的基本样式(凑合可以看)
<template>
<div class="hello">
<div class="swiper">
<img :src="imgArr[0].src" alt="" >
// 绑定的属性一定要用v-bind指令 : 是简写
<div>
<p>{{imgArr[0].title}}</p>
<span><</span>
<ul>
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
</ul>
<span>></span>
</div>
</div>
</div>
</template>
- JS部分
<script>
export default {
name: 'Swiper',
props: {
imgArr: {
// 接受一个数组类型imgArr参数, 默认值是空数组
type: Array,
default: []
}
},
data () {
return {
}
}
}
</script>
- app.vue代码
<template>
<div id="app">
<Swiper :imgArr="imgArr"></Swiper>
// 把imgArr传递给swipr组件
</div>
</template>
- js部分
<script>
import Swiper from './components/Swiper.vue'
// 引用swiper组件
export default {
name: 'app',
components : {
Swiper
// 声明使用Swiper组件
},
data() {
return {
imgArr: [
{
src:require("./images/1.jpg"), // js中引用图片路径一定要用require关键字, html和css部分不需要
title: '1.jpg'
},
{
src:require("./images/2.jpg"),
title: '2.jpg'
},
{
src:require("./images/3.jpg"),
title: '3.jpg'
},
{
src:require("./images/4.jpg"),
title: '4.jpg'
},
]
}
}
}
</script>
现在的页面应该是
接下来我们该去写切换逻辑部分
首先是把图片标号改成图片数组的长度, 不能写死
我们修改swiper.vue内的代码
接下来是点击编号跳转到相应的图片, 通过switchImg函数进行跳转
函数就是修改当前组件的currentNum, 达到显示哪一张图片
<template>
<div class="hello">
<div class="swiper">
<img :src="imgArr[currentNum].src" alt="" >
<div>
<p>{{imgArr[currentNum].title}}</p>
<span><</span>
<ul>
<li v-for="(item, index) in imgArr">
<a @click="switchImg(index)" href="javascripe:;">{{ index + 1 }}</a>
</li>
</ul>
<span>></span>
</div>
</div>
</div>
</template>
<script>
export default {
name: 'Swiper',
props: {
imgArr: {
type: Array,
default: []
}
},
data () {
return {
currentNum:0
}
},
methods: {
switchImg(index) {
this.currentNum = index;
}
}
}
</script>
- 接下来就是左右切换按钮跳转, 我们使用vue的计算属性特性
computed: {
nextNum() {
if (this.currentNum === 0) {
return this.imgArr.length-1
} else {
return this.currentNum - 1
}
},
preNum() {
if (this.currentNum === this.imgArr.length-1) {
return 0
} else {
return this.currentNum + 1
}
}
}
只需上一页下一页的按钮添加同样的事件, 把以上两个计算属性传入函数即可
<span @click="switchImg(nextNum)"><a href="javascripe:;"><</a></span>
<ul>
<li @click="switchImg(index)" v-for="(item, index) in imgArr">
<a href="javascripe:;">{{ index + 1 }}</a>
</li>
</ul>
<span @click="switchImg(preNum)"><a href="javascripe:;">></a></span>
- 接下来就是加入定时切换的功能, 我们只需要添加一个定时器即可, 再组件构建完毕就开始执行
interval() {
this.inv = setInterval(() => {
this.switchImg(this.preNum);
},this.time)
}
再添加一个传入的参数, 默认值是1000(1秒)
time: {
type: Number,
default: 1000
}
再组件初始化完毕后开始执行
created() {
this.interval();
}
- 再一个功能就是, 再移入的时候清空计数器, 移除之后再重启计时器
// 清除定时器
clearTime() {
clearInterval(this.inv)
},
// 重启定时器
setTime() {
this.interval();
}
再最外层的div加上两个出发函数
<div class="hello" @mouseover="clearTime" @mouseout="setTime">
- 最后一个功能就是, 是否自动播放
加入一个可传入参数autoPlay
autoPlay: {
type: Boolean,
default: true
}
然后处理一下刚才定义好的重启定时器和初始化完毕钩子函数
setTime() {
if(this.autoPlay) {
this.interval();
}
}
created() {
if(this.autoPlay) {
this.interval();
}
}
此时一个简单的swiper组件就构建完毕, 可传入一个图片地址数组, 一个自动播放事件, 是否自动播放三个参数
项目地址
从头开始开发一个vue幻灯片组件的更多相关文章
- vue-concise-slider 一个轻量的vue幻灯片组件
vue-concise-slider 一个轻量的vue幻灯片组件 阅读 541 收藏 35 2017-07-03 原文链接:github.com 外卖订单处理有烦恼?试试美团点评餐饮开放平台吧,可实现 ...
- 如何从0开发一个Vue组件库并发布到npm
1.新建文件夹在终端打开执行 npm init -y 生成package.json如下,注意如果要发布到npm,name不能有下划线,大写字母等 { "name": "v ...
- 如何抽象一个 Vue 公共组件
之前一直想写一篇关于抽象 Vue 组件的随笔,无奈一直没想到好的例子.恰巧最近为公司项目做了一个数字键盘的组件,于是就以这个为例聊聊如何抽象 Vue 的组件. 先上 Demo 与 源码.(demo最好 ...
- 从零开始开发一个vue组件打包并发布到npm (把vue组件打包成一个可以直接引用的js文件)
自己写的组件 有的也挺好的,为了方便以后用自己再用或者给别人用,把组件打包发布到npm是最好不过了,本次打包支持 支持正常的组件调用方式,也支持Vue.use, 也可以直接引用打包好的js文件, 配合 ...
- 从0到1发布一个Vue Collapse组件
需求背景 最近在项目中遇到了一个类似Collapse的交互需求,因此到github上找了一圈关于Vue Collapse的相关轮子,但是多少都有些问题.有的是实现问题,例如vue2-collapse, ...
- 自己开发的 vue 滑动按钮组件 vue-better-slider
写在前面的 这个人第一次尝试开发并发布一个 vue 的组件,该组件实现了类似 ios 手机淘宝客户端 -> 消息界面中消息的滑动删除功能等,如下为该组件的文档. 一个 Vue 的滑动按钮组件,有 ...
- 如何开发和发布一个Vue插件
前言 Vue 项目开发过程中,经常用到插件,比如原生插件 vue-router.vuex,还有 element-ui 提供的 notify.message 等等.这些插件让我们的开发变得更简单更高效. ...
- 一个vue的日历组件
说明: 1.基于element-ui开发的vue日历组件. 地址 更新: 1.增加value-format指定返回值的格式2.增加头部插槽自定义头部 <ele-calendar > < ...
- java+springBoot+Thymeleaf+vue分页组件的定义
导读 本篇着重介绍java开发环境下,如何写一个vue分页组件,使用到的技术点有java.springBoot.Thymeleaf等: 分页效果图 名称为vuepagerbasic的分页组件,只包含上 ...
随机推荐
- 理解JavaScript中的回调函数
理解回调函数,首先要知道在JavaScript中,函数也是对象,它可以赋值给变量,也可以作为参数传递给另一个函数.比如: var add=function(a,b){ console.log(a+b) ...
- ES6中set的用法回顾
ES6中的set类似一个数组,但是其中的值都是唯一的,Set本身是一个构造函数,用来生成 Set 数据结构. set函数可以接受一个数组作为参数,用来初始化: const set = new Set( ...
- ETCD 简介及基本用法
ETCD 项目地址 ETCD 官方文档 1. 简介 ETCD 是一个高可用的分布式键值数据库,可用于服务发现.ETCD 采用 raft 一致性算法,基于 Go 语言实现. 特点 简单:安装配置使用简单 ...
- Node.js实战2:模块使用入门。
NodeJS有丰富的三方模块,借助这些模块,可以快速的开发各类应用.这使用Nodejs可以进行很便捷.快速的开发. 1.安装与加载模块内核.三方 使用npm可以搜索.安装.卸载模块. 例: 搜索模块 ...
- Meet in the middle算法总结 (附模板及SPOJ ABCDEF、BZOJ4800、POJ 1186、BZOJ 2679 题解)
目录 Meet in the Middle 总结 1.算法模型 1.1 Meet in the Middle算法的适用范围 1.2Meet in the Middle的基本思想 1.3Meet in ...
- 数据库之Query Builder
Yii的查询构造器提供了一个用面向对象的方法来构造SQL语句.他让开发人员可以用类的方法,属性来作为SQL语句的一部分.然后把不同部分组装到一个正确的SQL语句中,调用DAO的方法来执行.下面的例子演 ...
- yum安装时出现No more mirrors to try.
可能原因:可能是不正常删除造成的 解决方法: yum clean allyum makecacheyum -y update 然后重新安装
- oracle至sqlplus的时候出现错误
那个啥,没记录到. 大概这么回事,上去的时候sqlplus不出命令. 然后source一下,出现了sqlplus. 但是呢,sqlplus / as sysdba的时候出现http——proxy ...
- JavaScript——实现继承的几种方式
实现继承的6中方法: 借用构造函数 组合继承 原型式继承 寄生式继承 寄生组合式继承 拷贝继承 1. 借用构造函数 在子类型构造函数的内部调用超类构造函数.通过使用apply()和call()方法在新 ...
- 基于GPU的图像处理平台
基于GPU的图像处理平台 1. (309)英伟达推Jetson TX1 GPU模块力推人工智能 1.1 产品概述 Jetson TX1 GPU模块,主要针对近年来蓬勃发展的人工智能市场,包括无人机. ...