vue实现循环滚动图片

 更新时间:2022-07-23 11:20:16   作者:佚名   我要评论(0)

本文实例为大家分享了vue实现循环滚动图片的具体代码,供大家参考,具体内容如下
效果(循环滚动,可切换方向):

轮播组件BaseSwiper.vue

本文实例为大家分享了vue实现循环滚动图片的具体代码,供大家参考,具体内容如下

 效果(循环滚动,可切换方向):

轮播组件BaseSwiper.vue:

<template>
? ? <div class="swiperBox">
? ? ? ? <img class="imgLeft" @click="clickLeft" src="../../../assets/img/左.png" alt="">
? ? ? ? <img class="imgRight" @click="clickRight" src="../../../assets/img/右.png" alt="">
? ? ? ? <div id="swiper">
? ? ? ? ? ? <div class="imgBox">
? ? ? ? ? ? ? ? <div class="imgDiv" v-for="(item,index) of imgList" :key="index">
? ? ? ? ? ? ? ? ? ? <img :src="item" />
? ? ? ? ? ? ? ? </div>
? ? ? ? ? ? </div>
? ? ? ? </div>
? ? </div>
</template>
<script>
export default {
? ? name: 'BaseSwiper',
? ? props: {
? ? ? ? speed: Number,
? ? ? ? direction: String,
? ? },
? ? data() {
? ? ? ? return {
? ? ? ? ? ? imgList: [
? ? ? ? ? ? ? ? require('../../../assets/img/组 14.png'),
? ? ? ? ? ? ? ? require('../../../assets/img/组 15.png'),
? ? ? ? ? ? ? ? require('../../../assets/img/组 17.png'),
? ? ? ? ? ? ? ? require('../../../assets/img/组 18.png'),
? ? ? ? ? ? ? ? require('../../../assets/img/组 24.png'),
? ? ? ? ? ? ],
? ? ? ? ? ? timer: null,
? ? ? ? ? ? theSpeed: this.speed,
? ? ? ? ? ? imgWidth: 260,
? ? ? ? ? ? theDirection: this.direction,
? ? ? ? }
? ? },
? ? methods: {
? ? ? ? clickLeft() {
? ? ? ? ? ? this.theDirection = 'left';
? ? ? ? },
? ? ? ? clickRight() {
? ? ? ? ? ? this.theDirection = 'right';
? ? ? ? },
? ? },
? ? mounted() {
? ? ? ? let imgBox = document.getElementsByClassName('imgBox')[0];
? ? ? ? //将imgBox下的图片进行拼接 循环展示图片
? ? ? ? imgBox.innerHTML += imgBox.innerHTML;
? ? ? ? let imgDiv = document.getElementsByClassName('imgDiv');
? ? ? ? imgBox.style.width = imgDiv.length * this.imgWidth + 'px';//设置div的宽度使图片可以放下
? ? ? ? let self = this;
? ? ? ? console.log(imgBox.offsetWidth,imgBox.style.width )
? ? ? ? function autoScroll() {
? ? ? ? ? ? if (imgBox.offsetLeft < -(imgBox.offsetWidth / 2)) {//提前更新left值,实现循环展示
? ? ? ? ? ? ? ? imgBox.style.left = 0;
? ? ? ? ? ? }
? ? ? ? ? ? if (imgBox.offsetLeft > 0) {//向右滚动 提前更新left值,实现循环展示
? ? ? ? ? ? ? ? imgBox.style.left = -(imgBox.offsetWidth / 2) + 'px';
? ? ? ? ? ? }
? ? ? ? ? ? if (self.theDirection == 'left') { //向左滚动,值为负
? ? ? ? ? ? ? ? self.theSpeed = -Math.abs(self.theSpeed)
? ? ? ? ? ? } else { //向右滚动
? ? ? ? ? ? ? ? self.theSpeed = Math.abs(self.theSpeed)
? ? ? ? ? ? }
? ? ? ? ? ? // 求出总的left值,等于left值加上移动的速度(px值)
? ? ? ? ? ? imgBox.style.left = imgBox.offsetLeft + self.theSpeed + 'px';
? ? ? ? }
? ? ? ? this.timer = setInterval(autoScroll, 30);//全局变量 ,保存返回的定时器
? ? },
? ? beforeDestroy() {
? ? ? ? clearInterval(this.timer);
? ? ? ? this.timer = null;
? ? }
}
</script>
<style scoped lang='less'>
.swiperBox {
? ? height: 100%;
? ? width: 100%;
? ? position: relative;
? ? .imgLeft {
? ? ? ? left: 0;
? ? ? ? top: 40%;
? ? }
? ? .imgLeft,
? ? .imgRight {
? ? ? ? width: 27px;
? ? ? ? height: 38px;
? ? ? ? position: absolute;
? ? ? ? cursor: pointer;
? ? }
? ? .imgRight {
? ? ? ? right: 0;
? ? ? ? top: 40%;
? ? }
? ? .directionIcon:hover {
? ? ? ? opacity: 1;
? ? }
? ? #swiper {
? ? ? ? width: 90%;
? ? ? ? height: 100%;
? ? ? ? margin: 0 auto;
? ? ? ? overflow: hidden;
? ? ? ? position: relative;
? ? ? ? .imgBox {
? ? ? ? ? ? height: 100%;
? ? ? ? ? ? position: absolute;
? ? ? ? ? ? left: 0;
? ? ? ? ? ? top: 0;
? ? ? ? ? ? overflow: hidden;
? ? ? ? ? ? display: flex;
? ? ? ? ? ? .imgDiv {
? ? ? ? ? ? ? ? width: 100%;
? ? ? ? ? ? ? ? margin-left: 15px;
? ? ? ? ? ? ? ? img {
? ? ? ? ? ? ? ? ? ? height: 100%;
? ? ? ? ? ? ? ? ? ? width: 280px;
? ? ? ? ? ? ? ? ? ? // width: 260px;
? ? ? ? ? ? ? ? ? ? // height: 120px;
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? }
? ? }
}
</style>

父组件调用,只贴出关键代码:

<Swiper :speed="2" :direction="'left'"></Swiper>
?
//引用
import Swiper from '../BaseSwiper/BaseSwiper'
?
components: { Swiper },

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
  • vue实现列表无缝循环滚动
  • vue实现公告消息横向无缝循环滚动
  • 基于vue实现循环滚动列表功能
  • Vue实现一种简单的无限循环滚动动画的示例
  • vue实现循环滚动列表
  • 使用vue?v-for循环图片路径方式
  • 在vue中v-for循环遍历图片不显示错误的解决方案
  • 解决vue的 v-for 循环中图片加载路径问题
  • vue2.0 循环遍历加载不同图片的方法
  • vue实现图片滚动的示例代码(类似走马灯效果)

您可能感兴趣的文章:

相关文章

  • vue实现循环滚动图片

    vue实现循环滚动图片

    本文实例为大家分享了vue实现循环滚动图片的具体代码,供大家参考,具体内容如下 效果(循环滚动,可切换方向): 轮播组件BaseSwiper.vue
    2022-07-23
  • 在nest.js中通过正则表达式正确设置验证的方法

    在nest.js中通过正则表达式正确设置验证的方法

    下面看下nest.js正则表达式设置验证的方法,代码如下所示: import { IsNotEmpty, Length, Matches, Max, Min } from "class-validator";
    2022-07-23
  • 利用正则表达式进行中文排版的实例教程

    利用正则表达式进行中文排版的实例教程

    目录前言〇、常见匹配类一、段落排版类1、非段落换行排版(要求段落之间空一行)2、插入空行3、删除空行4、行首批量添加(替换项为2个空格时
    2022-07-23
  • 最新最全的手机号验证正则表达式

    最新最全的手机号验证正则表达式

    目录前言各大运营商手机号码段(新)表单字段验证常用正则表达式总结前言 一般表单页面都需要填写手机号,校验用户输入的手机号码是否正确,
    2022-07-23
  • JavaScript正则表达式实现注册信息校验功能

    JavaScript正则表达式实现注册信息校验功能

    目录注册信息校验需求案例分析Java和JavaScript正则表达式的对比 Java中也有正则表达式,默认情况下必须要精确匹配 ;而在JS中默认是模糊匹配,
    2022-07-23
  • 正则表达式拆分url实例代码

    正则表达式拆分url实例代码

    目录背景案例使用js举例使用java举例正则说明总结背景 做web开发的同学,经常会有从url中获取二级域名或者主域名或者参数等等需求,需要扎实
    2022-07-23
  • 一篇文章了解正则表达式的替换技巧

    一篇文章了解正则表达式的替换技巧

    目录1.正则表达式应用——替换指定内容到行尾2.正则表达式应用——数字替换3.正则表达式应用——删除每一行行
    2022-07-23
  • 使用正则表达式从链接中获取图片名称

    使用正则表达式从链接中获取图片名称

    目录需求介绍分析链接中存在参数链接中不存在参数方法一方法二方法三总结需求介绍 后端的数据接口返回图片链接列表,前端将图片列表渲染出来
    2022-07-23
  • 正则表达式基础与常用验证表达式

    正则表达式基础与常用验证表达式

    目录一、正则元字符1、 字符元字符2、重复元字符(量词)3、定位元字符4、分组和替换字符5、特殊字符6、需要转义的字符7、贪婪与非贪婪匹配8
    2022-07-23
  • JSP实现简单网页计算器

    JSP实现简单网页计算器

    本文实例为大家分享了JSP实现简单网页计算器的具体代码,供大家参考,具体内容如下 一、构造一个简单的计算器,能够进行“+、—、
    2022-07-23

最新评论