Vue实现图片轮播组件思路及实例解析

作者:指间流逝的夏末 时间:2023-07-02 17:02:02 

1、先看效果:

Vue实现图片轮播组件思路及实例解析

熟悉的图片轮播,只要是个网站,百分之90以上会有个图片轮播。我认为使用图片轮播。

第一可以给人以一种美观的感受,而不会显得网站那么呆板,

第二可以增加显示内容,同样的区域可以显示更多内容。

2、每学一个新东西 ,图片轮播都是很好的练手案例,而且,也很实用。

    3、基本要求:页面加载,自动播放。鼠标悬停,停止播放。鼠标离开,继续播放

点击左右箭头切换上一张,下一张图片。

下方小圆点显示当前位第几张图片。

4、使用Vue实现

5、示例代码

结构html:


<template>
<div id="slider">
 <div class="window" @mouseover="stop" @mouseleave="play">
  <ul class="container" :style="containerStyle">
   <li>
    <img :style="{width:imgWidth+'px'}" :src="sliders[sliders.length - 1].img" alt="">
   </li>
   <li v-for="(item, index) in sliders" :key="index">
    <img :style="{width:imgWidth+'px'}" :src="item.img" alt="">
   </li>
   <li>
    <img :style="{width:imgWidth+'px'}" :src="sliders[0].img" alt="">
   </li>
  </ul>
  <ul class="direction">
   <li class="left" @click="move(600, 1, speed)">
    <svg class="icon" width="30px" height="30.00px" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg"><path fill="#ffffff" d="M481.233 904c8.189 0 16.379-3.124 22.628-9.372 12.496-12.497 12.496-32.759 0-45.256L166.488 512l337.373-337.373c12.496-12.497 12.496-32.758 0-45.255-12.498-12.497-32.758-12.497-45.256 0l-360 360c-12.496 12.497-12.496 32.758 0 45.255l360 360c6.249 6.249 14.439 9.373 22.628 9.373z" /></svg>
   </li>
   <li class="right" @click="move(600, -1, speed)">
    <svg class="icon" width="30px" height="30.00px" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg"><path fill="#ffffff" d="M557.179 904c-8.189 0-16.379-3.124-22.628-9.372-12.496-12.497-12.496-32.759 0-45.256L871.924 512 534.551 174.627c-12.496-12.497-12.496-32.758 0-45.255 12.498-12.497 32.758-12.497 45.256 0l360 360c12.496 12.497 12.496 32.758 0 45.255l-360 360c-6.249 6.249-14.439 9.373-22.628 9.373z" /></svg>
   </li>
  </ul>
  <ul class="dots">
   <li v-for="(dot, i) in sliders" :key="i"
   :class="{dotted: i === (currentIndex-1)}"
   @click = jump(i+1)
   >
   </li>
  </ul>
 </div>
</div>
</template>

CSS部分:


*{
   box-sizing: border-box;
   margin:0;
   padding:0;
  }
  ol,ul{
   list-style: none;
  }
  #slider{
   text-align: center;
  }
  .window{
   position:relative;
   width:600px;
   height:400px;
   margin:0 auto;
   overflow:hidden;
  }
  .container{
   display:flex;
   position:absolute;
  }
  .left, .right{
   position:absolute;
   top:50%;
   transform:translateY(-50%);
   width:50px;
   height:50px;
   background-color:rgba(0,0,0,.3);
   border-radius:50%;
   cursor:pointer;
  }
  .left{
   left:3%;
   padding-left:12px;
   padding-top:10px;
  }
  .right{
   right:3%;
   padding-right:12px;
   padding-top:10px;
  }
  img{
   user-select: none;
  }
  .dots{
    position:absolute;
    bottom:10px;
    left:50%;
    transform:translateX(-50%);
   }
  .dots li{
   display:inline-block;
   width:15px;
   height:15px;
   margin:0 3px;
   border:1px solid white;
   border-radius:50%;
   background-color:#333;
   cursor:pointer;
  }
  .dots .dotted{
   background-color:orange;
  }

JavaScript部分:


script>
export default {
name: 'slider',
props: {
 initialSpeed: {
  type: Number,
  default: 30
 },
 initialInterval: {
  type: Number,
  default: 3
 }
},
data () {
 return {
  sliders:[
   {
    img:'http://img.hb.aicdn.com/adbde61e4343dedd21e97ea7f22666825a8db7d077ffe-qn8Pjn_fw658'
   },
   {
    img:'http://img.hb.aicdn.com/adeed7d28df6e776c2fa6032579c697381d1a82b7fe00-fwRqgn_fw658'
   },
   {
    img:'http://img.hb.aicdn.com/ab7f48509b3c0353017d9a85ef1d12400c9b2724540d4-p3zouo_fw658'
   },
   {
    img:'http://img.hb.aicdn.com/60f788fc2a846192f224b9e6d4904b30e54926211d3d67-ACFJ9G_fw658'
   },
   {
    img:'http://img.hb.aicdn.com/22ded455284aab361b8d2056e82f74a891a019704296a-PSraEB_fw658'
   },
  ],
  imgWidth:600,
  currentIndex:1,
  distance:-600,
  transitionEnd: true,
  speed: this.initialSpeed
 }
},
computed:{
 containerStyle() {
  return {
   transform:`translate3d(${this.distance}px, 0, 0)`
  }
 },
 interval() {
  return this.initialInterval * 1000
 }
},
mounted() {
 this.init()
},
methods:{
 init() {
  this.play()
  window.onblur = function() { this.stop() }.bind(this)
  window.onfocus = function() { this.play() }.bind(this)
 },
 move(offset, direction, speed) {
  console.log(speed)
  if (!this.transitionEnd) return
  this.transitionEnd = false
  direction === -1 ? this.currentIndex += offset/600 : this.currentIndex -= offset/600
  if (this.currentIndex > 5) this.currentIndex = 1
  if (this.currentIndex < 1) this.currentIndex = 5

const destination = this.distance + offset * direction
  this.animate(destination, direction, speed)
 },
 animate(des, direc, speed) {
  if (this.temp) {
   window.clearInterval(this.temp);
   this.temp = null ;
  }
  this.temp = window.setInterval(() => {
   if ((direc === -1 && des < this.distance) || (direc === 1 && des > this.distance)) {
    this.distance += speed * direc
   } else {
    this.transitionEnd = true
    window.clearInterval(this.temp)
    this.distance = des
    if (des < -3000) this.distance = -600
    if (des > -600) this.distance = -3000
   }
  }, 20)
 },
 jump(index) {
  const direction = index - this.currentIndex >= 0 ? -1 : 1;
  const offset = Math.abs(index - this.currentIndex) * 600;
  const jumpSpeed = Math.abs(index - this.currentIndex) === 0 ? this.speed : Math.abs(index - this.currentIndex) * this.speed ;
  this.move(offset, direction, jumpSpeed)
 },
 play() {
  if (this.timer) {
   window.clearInterval(this.timer)
   this.timer = null
  }
  this.timer = window.setInterval(() => {
   this.move(600, -1, this.speed)
  }, this.interval)
 },
 stop() {
  window.clearInterval(this.timer)
  this.timer = null
 }
}
}
</script>

来源:https://www.cnblogs.com/zhangyongl/p/8870064.html

标签:Vue,图片,轮播,组件
0
投稿

猜你喜欢

  • PHP 检查扩展库或函数是否可用的代码

    2023-07-22 23:34:34
  • 来看看如何防止采集

    2007-08-19 20:11:00
  • Python标准库之随机数 (math包、random包)介绍

    2021-09-26 11:57:08
  • Python光学仿真理解Jones矩阵学习

    2022-03-10 21:11:39
  • 对Python Pexpect 模块的使用说明详解

    2022-10-24 02:14:09
  • Django外键(ForeignKey)操作以及related_name的作用详解

    2023-03-15 22:48:09
  • mysql事务处理用法与实例代码详解

    2024-01-14 04:55:08
  • python和websocket构建实时日志跟踪器的步骤

    2023-08-11 08:28:20
  • 解读数据库的嵌套查询的性能问题

    2024-01-20 17:00:06
  • SUSE Linux下源码编译方式安装MySQL 5.6过程分享

    2024-01-14 21:55:50
  • Python面向对象程序设计类的封装与继承用法示例

    2022-12-22 08:34:33
  • Python中socket网络通信是干嘛的

    2023-12-16 02:57:03
  • Oracle过程与函数的区别分析

    2024-01-15 20:15:37
  • 天气预报调用代码

    2008-11-18 15:59:00
  • windows下安装、卸载mysql服务的方法(mysql 5.6 zip解压版安装教程)

    2024-01-13 04:56:20
  • 详解python使用canvas实现移动并绑定键盘

    2022-08-18 01:02:52
  • 解析Python中的eval()、exec()及其相关函数

    2023-12-16 02:51:59
  • python实现备份目录的方法

    2022-10-30 02:54:04
  • 如何编写一个创建FTP站点的函数?

    2009-11-07 18:51:00
  • mysql 数据类型TIMESTAMP

    2024-01-17 17:04:57
  • asp之家 网络编程 m.aspxhome.com