首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js实现单张或多张图片持续无缝滚动

背景: 想要实现图片持续滚动,既然使用js,就千万不要加css动画、过渡等相关样式,如果想要滚动的平滑一下,可以一像素一像素的感动,则很平滑,如果加了过渡动画,当图片重置为0时,会有往回倒的动画效果,跟预期不符...原理: 图片滚动原理同图片轮播原理,同样也适用于文字滚动等一系列滚动,通过复制最后一张图片或最后一堆文字插入第一行,或复制第一张图片或一堆文字插入在结尾,来实现无缝拼接,前提:1、必须是没有设置过渡动画的...,2、重置为0的时候与当前已经滚动到的高度对于图片的位置而言肉眼看上去没变化。...实现: html主要包含三块: 1、最外层盒子,用来展示滚动图的区域,overflow:hidden; 2、滚动的盒子,主要改变该盒子的定位值,来实现滚动,里面包含所有要滚动的图片或文字 3、包含图片或文字的盒子...代码: class Roll { constructor(opts) { this.elem = opts.elem; // 图片包含滚动长度的元素的 this.elemBox

7.6K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    vue如何实现列表自动滚动、向上滚动的效果

    研究了一个插件 列表自动滚动的插件vue-seamless-scroll感受这是个做大屏可视化时可靠帮手请欣赏一下效果图如图所示可以看到 它自动向上滚动 以及鼠标移动进入表格则停止滚动1.第一步进行安装...npm install vue-seamless-scroll --save2.在main.js直接导入使用import scroll from 'vue-seamless-scroll'Vue.use...(scroll)3.建立了一个Test.vue来使用(结合element-ui中的表格来一起实现的) 的滚动) direction => 0/1 singleWidth: 0, // 单步运动停止的宽度(默认值0是无缝不停止的滚动) direction...,即轮播表,我们可以使用 vue-seamless-scroll 来实现,使用起来也很方便vue-seamless-scroll官网:vue-seamless-scrollNPM npm install

    66110

    requestAnimationFrame实现单张图片无缝持续滚动

    背景 在很久以前,有写过一个使用 js 实现单张图片持续滚动图片的 代码,但那一版实现会持续操作DOM,向DOM中插入元素,性能较差,最近发现 requestAnimationFrame 通过 动画的方式实现图片滚动更加方便...效果如下 需求描述 需要单张图片在可视区域内无缝持续向上滚动或向左滚动,由于向下和向右属于反着坐标轴移动图片,和正常DOM元素插入展示顺序也相反,遂不考虑此种场景。 代码实现 图片所展示区域的窗口view // step 每次移动的距离 // direction: 滚动方向,默认 "top" 持续向上滚动...2022.03.09 更新 2、发现在有些场景下图片onload事件触发之后,依然获取不到图片宽高,而上面我们图片滚动是依赖图片的宽高的,这里需要再加个定时器,轮询获取图片宽高,当确实可以获取到宽高之后...0的边界长度 let boundaryValue = 0; // 是否可以执行滚动动画,保证获取到图片真实宽高之后再开始滚动,否则获取不到宽高,始终不会滚动 let canScroll

    3.5K20

    教你简单实现RecyclerView自动滚动

    当RecyclerView内容过多,超出屏幕的时候,需要让它自己滚动展示数据,尤其是某些Android设备处于高处,或是不可被触摸点击的,这样的情况下,让其自己滚动展示数据尤为重要了 自动滚动的方案有很多种...,目前比较常见又最简单的一种是:继承至RecyclerView,并实现runnable方法,每间隔10ms(delayTime)就去执行scrollby(x,y)方法,其中delayTime和x,y的值决定了滚动速度...= null private var running //是否正在滚动 = false private var canRun //是否可以自动滚动,根据数据是否超出屏幕来决定...} } 上面代码实现了最基本的滚动功能,但有时候Adnroid设备可以触摸的话,而当前recyclerview正在滚动,又去滑动它,那就会造成界面错乱,数据错乱了,所以还需要重写拦截onTouchEvent...方法,当触摸到recyclerview的时候,即在ACTION_DOWN的时,停止滚动线程,在ACTION_UP、ACTION_CANCEL时再开启线程。

    1.1K40

    rAF实现表格内容自动滚动

    rAF实现表格内容自动滚动 前言 实习导师让我实现表格内容自动滚动,实际就是大屏项目可能会用上的。正好之前看到rAF的介绍,实际上也没用过,所以就用rAF来玩一波。...目标: 让表格的内容会自动滚动 鼠标悬浮,动画停止 到底后会自动回到顶部,继续滚动 element表格自带滚动 首先呢,element的表格是自带了滚动效果的,但是需要小小的设置一下。...这个时候可能会想:直接使用overflow: auto;不就能实现表格滚动了吗?但是,这个表格滚动效果并不是想要的表格内容滚动。表头也会滚不见。...窗口没激活时,动画将暂停以提升性能和电池寿命 实现自动滚动 获取el-scrollbar 容器 需要实现自动滚动,首先得获取el-scrollbar 容器。...我们判断到底后,就使用原生js的scrollTo方法,就能让它回到顶部。

    2.1K20

    Vue 实现图片监听鼠标滑轮滚动实现图片缩小放大功能

    前言其实想要实现功能很简单,就是在一张图片上监听鼠标滑轮滚动的事件,然后根据上滚还是下滚实现图片的缩放。...实现思路在js中,onmousewheel是鼠标滑轮滚动事件,可以通过这个事件触发来改变图片的大小,实现图片放大缩小功能。但是我们这里是vue所以使用的是:mousewheel。...this.imgWidth = `${this.imgWidth}px`; console.log(this.imgWidth, this.imgHeight, "hou"); }, },当鼠标在这个图片滚动滑轮的时候就会被这个时间监听到...单纯的使图片缩小放大还不至于使用防抖和节流啥的,但是如果需要请求后台记得做好防抖。...在页面有滚动条的时候,滚动条会随着鼠标滚轮滚动而滚动,这是浏览器的默认行为,可用return false来取消浏览器的默认行为。有火狐鼠标滚轮兼容问题。

    3.7K20

    游戏中怎么实现滚动数字?Cocos Creator 实现!

    效果预览 ▌滚动数字的效果预览,位数设置:10,初始值:0,测试时,把显示数字手动修改为 1234567890 的效果,#免费提供代码#,具体获取方法,参考文章结尾部分。 ?...▌RollNumber 组件支持显示位数、运动速率的设置,使用时,需要设置每一位数字的显示宽度 width(注意不是所有位数的宽度),还需要设置 0-9 每个数字的纹理图片,并对应上数组下标,如下图所示...实现原理 ▌具体的原理是,每一位一开始把 0-9-0 数字竖直方向拼接,都置于 Layout 组件内,从上到下排列,需要显示的区域通过遮罩显示,其他不需要显示部位就不会显示出来,当需要显示指定数字时,改变父节点的纵轴坐标实现需要的数字显示...▌考虑到数字的长度可能会发生变化,使用节点池可以提升效率,需要的时候,从节点池获取,如果节点池是空的,重新生成。...▌数字运动的距离有长有短,计算运动时间时,需要根据偏移量计算运动时间,以达到每一位在相同时间内完成数字的变化。

    2.1K10

    MacOS 实现自动切换鼠标滚动方向

    实现效果 想在 macOS 上实现如下效果: 连接了(非 Magic Mouse)鼠标时,系统自动切换鼠标滚动方向为“非自然”; 断开鼠标连接时(使用触控板),系统自动切换鼠标滚动方向为“自然”。...实现方式 使用 AppleScript 实现切换滚动方向 切换滚动方向为 “自然” scroll-direction-trackpad.applescript[1] tell application "...使用 Automator + Login Items 实现登录后自动检查 Automator 通常我们可能是在主要工作场所使用外接键鼠设备,在临时工作场所使用触控板。...这时候我们可以通过 macOS 自带的 Automator 应用,将上面的检测切换脚本制作成一个 app, 并设置为登录后自动执行,以实现不同工作场景自动切换鼠标滚动方向的效果。...Login Items 在 系统偏好设置 -> 用户与群组 -> 登录项 中添加刚刚创建的应用,这样每次登录后就会自动执行了。

    28910

    纯css实现单张图片无限循环无缝滚动

    一、用js setInterval定时器实现 js实现要通过不断的改变定位、复制图片的方式来做,效果极其不稳定 二、用css3 animation动画实现 需求1动画: @-webkit-keyframes...注意: 1、前提是把一张图片复制成3张,以实现无缝滚动,网上看了很多人此类无缝循环滚动的方法,实现出来之后,每次回到起点都会有跳动的感觉,这里经过摸索,给动画上移的距离设为图片的高度,就不会有跳动问题了...,完美无限循环+无缝滚动; 2、图片每停3s滚动一次,且每次刚好停在正中间,上线留的衔接的图片距离相等,这里就要计算一下,每次动画上移距离= 图片实际显示高度-(所在区域的总高度-上间距高度)。...以下是图片滚动的js,如果要实现动态获取图片高度,则需要写下面的js: function addKeyFrames(height,offsetHeight){ let style = document.createElement...,adLeftHeight); } } 以上js对应的html: <div class="image-box"

    3.8K30
    领券