怎样用原生js配合css的transition写个无缝滚动

之所以想要写原生js配合css转换的无缝滚动,是因为之前在简书上看到一哥们写的一篇文章,说是在网上找了一堆js配合css transition属性写的轮播插件,可惜没有无缝的效果,结果他用原生js重写了一个可以无缝滚动的。好吧,我觉得这哥们的精神还是值得表扬的,只是原生实现略显麻烦,也很难把握性能(利用定时器写的动画很容易有性能问题)。

原生JavaScript无缝轮播图特效 附上链接方便大家一同对比学习

其实原生js配合css转换写个无缝滚动要比直接用原生js写起来简单得多,而且性能非常好。希望通过这篇文章能起到抛砖引玉的笑果!哈哈哈哈,二话不说,上码!!!

首先附上相应的HTML和CSS:

html

<div class="box"><ul id="box"><li>158****546已购买1个月</li><li>158****546已购买2个月</li><li>158****546已购买3个月</li><li>158****546已购买4个月</li><li>158****546已购买5个月</li><li>158****546已购买1个月</li></ul></div>
复制代码

css

     .box{width: 300px;height: 40px;overflow: hidden;border: 1px solid rebeccapurple;}.box>ul{margin: 0;padding: 0;}.box>ul>li{list-style-type: none;width: 300px;height: 40px;line-height: 40px;}.count{font-size: 24px;}
复制代码

细心的朋友可能会发现HTML上面首尾两个li是一样的(哈哈哈,就是说明一下它俩是一样的)上图!!啊哈哈哈哈,将就看一下,我画了好久的。这里为了节约空间就横着放了,下面的例子的滚动是向上走的。

当焦点位于图片1的副本(即红框那个1)时,那一瞬间让整个列表回到初始的位置,即第一个1在红框内。对,最后面这个副本1就是为了让用户产生视觉差。

下面开始编写相应的js,先写一个构造函数,然后把获取的id以及向上滑动的数值作为私有变量写死在构造函数里面:

function sliderBox() {var list = document.getElementById('box'),newPosition = 0,  //这里以ul作为位移目标,newPosition为ul每次的位置offset = -40;   //每次要上移的数值(先默认为上移)
}
复制代码

然后在构造函数里面写一个私有函数

function animate () {newPosition+=offset;list.style.transition = "transform 0.6s";list.style.transform = "translateY(" + newPosition + "px)";if (newPosition < -160) {setTimeout(function () {newPosition = 0;list.style.transition = "";list.style.transform = "translateY(0)";}, 600);}}
复制代码

我们今天要说的是无缝滚动,到底在哪体现出无缝呢?上面的代码怎么多出了一行list.style.transition?为什么不直接写死在ul上面呢?因为这就是用原生js配合css转换写无缝滚动的关键所在!!

当列表静悄悄地重一开始滑到第五个的时候,这是newPosition刚好等于-160,也就是说ul的translateY为-160,这时候再来那么一下,这么一下照常的会执行这三行:

newPosition+=offset;
list.style.transition = "transform 0.6s";
list.style.transform = "translateY(" + newPosition + "px)";
复制代码

是的,就在这一下的transition过渡完的那一瞬间,setTimeout可以执行了。没错,就跟前面画的图一样,setTimeout里面的意思就是要让ul回到最起始的位置。

这里需要注意的是,setTimeout的延迟时间和transition的过渡时间必须保持一致,这里就是保持无缝的最关键所在了。

到这里就算是讲完了,其实没多少东西,理解了就很简单。最后祭上代码

html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><style>.box{width: 300px;height: 40px;overflow: hidden;border: 1px solid rebeccapurple;}.box>ul{margin: 0;padding: 0;}.box>ul>li{list-style-type: none;width: 300px;height: 40px;line-height: 40px;}.count{font-size: 24px;}</style>
</head>
<body><div class="box"><ul id="box"><li>158****546已购买1个月</li><li>158****546已购买2个月</li><li>158****546已购买3个月</li><li>158****546已购买4个月</li><li>158****546已购买5个月</li><li>158****546已购买1个月</li></ul></div><script src="./slider2.js"></script><script>window.onload = function () {sliderBox();}</script>
</body>
</html>
复制代码

js

function sliderBox() {var list = document.getElementById('box'),newPosition = 0,offset = -40;if (!(this instanceof sliderBox)) {return new sliderBox().init();}this.init = function () {setInterval(animate, 3000);};function animate () {newPosition+=offset;list.style.transition = "transform 0.6s";list.style.transform = "translateY(" + newPosition + "px)";if (newPosition < -160) {setTimeout(function () {newPosition = 0;list.style.transition = "";list.style.transform = "translateY(0)";}, 600);}}
}
复制代码

在下文笔拙劣,有什么不清楚或者有出入的地方,烦请斧正!欢迎留言!也希望能给我点赞,鼓励我写出更好的文章。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/282689.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

聊聊策略模式

1、简介策略模式就是把各个平等的具体实现进行抽象、封装成为独立的算法类&#xff0c;然后通过上下文和具体的算法类来进行交互。各个策略算法都是平等的&#xff0c;地位是一样的&#xff0c;正是由于各个算法的平等性&#xff0c;所以它们才是可以相互替换的。虽然我们可以动…

小学计算机课每周几节,小学信息技术课时多少

满意答案小学信息技术课程标准一、课程任务和教学目标中小学信息技术课程的主要任务是&#xff1a;培养学生对信息技术的兴趣和意识&#xff0c;让学生了解和掌握信息技术基本知识和技能&#xff0c;了解信息技术的发展及其应用对人类日常生活和科学技术的深刻影响。通过信息技…

张旭升20162329 2006-2007-2 《Java程序设计》第一周学习总结

20162329 2006-2007-2 《Java程序设计》第一周学习总结 教材学习内容总结 通过打书上的代码熟悉了Java编程的基本过程 教材学习中的问题和解决过程 1.因为我的虚拟机不可用所以我在Windows中安装了bash和git&#xff0c;但是由于Windows下bash中没有中文而且我英语又不是很好所…

《图解 HTTP》读书笔记(未完待续)

ARP 协议&#xff08;Address Resolution Protocol&#xff09;一种以解析地址的协议&#xff0c;根据通信双方的 IP 地址就可以查出对应的 MAC 地址。MAC&#xff08; Media Access Control Address&#xff09;地址是指网卡所属的固定的地址MIME&#xff0c;多部分对象集合&a…

SQL查询的安全方案

1.使用预处理语句防sql注入 2.写入数据库的数据要进行特殊字符转义 3.错误信息不返回给用户,记录到日志 4.定期做数据备份 5.不给查询用户root权限,合理分配权限 6.关闭远程访问数据库权限 7.修改root口令,不使用默认口令,使用较复杂口令 8.删除多余的用户 9.改变root用户的名称…

.NET 实现启动时重定向程序运行路径及 Windows 服务运行模式部署

日常工作中有时候会遇到需要将程序直接在服务器上运行&#xff0c;而不依赖于 IIS 托管的情况&#xff0c;直接运行有两种方式&#xff0c;一种是部署为 服务模式&#xff0c;另一种则是 直接启动 .NET 发布之后的 exe 文件以 控制台模式运行&#xff0c;控制台模式运行主要问题…

iOS runtime实战应用:关联对象

在开始之前建议先阅读iOS runtime的基础理解篇&#xff1a;iOS内功篇&#xff1a;runtime 有筒子在面试的时候&#xff0c;遇到这样一个问题&#xff1a;“如何給NSArray添加一个属性&#xff08;不能使用继承&#xff09;”&#xff0c;筒子立马蒙逼了&#xff0c;不能用继承&…

黑龙江科技大学计算机考研复试科目,2020年黑龙江科技大学计算机应用技术考研经验分享...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼育明考研备考策略随着IT业的迅猛发展&#xff0c;各高校计算机专业报名火爆&#xff0c;甚至文科学生跨专业报考时都会选择计算机。计算机专业竞争日趋激烈&#xff0c;那么如何在充分发挥公共科目优势的同时&#xff0c;尽量缩小专…

Mysql数据库安全性问题【防注入】

一、SQL注入实例 后台的插入语句代码&#xff1a; $unsafe_variable $_POST[user_input]; mysql_query("INSERT INTO table (column) VALUES ($unsafe_variable)"); 当POST的内容为&#xff1a; value); DROP TABLE table;--以上的整个SQL查询语句变成&#xff1…

Unexpected end of JSON input while parsing near错误解决方式(网上的方法)

原本是想创建一个create-react-app来着&#xff0c;但是在创建的中间会出现Unexpected end of JSON input while parsing near... 的错误。 在网上找到了一些方法&#xff0c;首先是清空npm的缓存。 npm cache clean --force 氮素&#xff0c;然并卵。near后面的内容变化了一下…

解决Qt5 Creator无法切换输入法(fcitx),Ubuntu中不能使用搜狗输入法录入汉字问题...

2016年6月8日修正&#xff0c;ubuntu 16.04 Qt5.7.0 以及 Qt5.6.1均测试通过在Qt5.3之前&#xff0c;我发布过解决办法 解决Qt5 Creator无法切换输入法&#xff08;fcitx&#xff09;&#xff0c;不能录入汉字问题&#xff0c;Qt5.4以及Qt5.5&#xff0c;旧办法失效&#xff0c…

目前市场上用于个人计算机的硬盘尺寸是,第5章-硬盘(计算机组装与维护).docx

ADDIN CNKISM.UserStyle一、选择题1.磁盘存储器的主要技术指标有多项&#xff0c;下面不属于硬盘指标的是( )。A.存储容量B.单碟容量C.转速D.带宽2.硬盘的平均寻道时间通常以毫秒为单位测量&#xff0c;是指( )。A.磁头从一个柱面移到另一个随机距离远的柱面所需的平均时间B.…

Xmemcached学习笔记一(安装memcached)

memcached有三种java客户端 第一种&#xff1a;Com.danga 包下面的memcached&#xff0c;需引入jar(本人用的是memcached-2.5.2.jar 文末附上附件需要的可以下载) 第二种&#xff1a;spyMemcached 第三种&#xff1a;XMemcached 据说第三种是使用最简单&#xff0c;最好用的&a…

WrapPanel 实现虚拟化

WrapPanel 实现虚拟化控件名&#xff1a;VirtualizingWrapPanel作者&#xff1a;WPFDevelopersOrg原文链接&#xff1a; https://github.com/WPFDevelopersOrg/WPFDevelopers框架使用大于等于.NET40&#xff1b;Visual Studio 2022;项目使用 MIT 开源许可协议&#xff1b;众…

pdo连接mysql数据库(简洁明了)

一 实例化pdo对象 $dsn "mysql:dbnametest;host127.0.0.1"; $pdo new PDO($dsn,root,root);二 数据查询 1、如果不根据用户传过来的值进行操作,可以直接query sql $dsn "mysql:dbnametest;host127.0.0.1"; $pdo new PDO($dsn,root,root); $sql &qu…

一次微信小程序的快速开发体验

起因 事情是这样的 一天早上组里还早激烈的讨论某个项目的可用性和发展前景&#xff0c;突然老大说了句&#xff0c;能不能做个小程序的版本呢&#xff1f;然后大家纷纷讨论起来&#xff0c;有反对有支持&#xff0c;我就说了一句&#xff0c;刚出来的时候搞过一会。。。然后就…

造数据时踏过的坑

1.在产生随机数时,在数据规模很大的时候很难出现自己要的模型,比如某个条件的数据量,此时要写一个方法,来造一批这样的数据 2.将控制数量,文件路径写成配置文件的形式,以免重复打包 3.输入输出文件夹,可以配置以免重复打包 转载于:https://www.cnblogs.com/rocky-AGE-24/p/7376…

如何证明 ConcurrentDictionary 字典操作不全是线程安全的

前言最近&#xff0c;看到一篇文章&#xff0c;讲到《ConcurrentDictionary字典操作竟然不全是线程安全的&#xff1f;》。首先&#xff0c;这个结论是正确的&#xff0c;但文中给出的一个证明例子&#xff0c;我觉得是有问题的。相关代码如下&#xff1a;using System.Collect…

微型计算机及接口技术试题,1月自考微型计算机及其接口技术试题及答案解析...

《1月自考微型计算机及其接口技术试题及答案解析》由会员分享&#xff0c;可在线阅读&#xff0c;更多相关《1月自考微型计算机及其接口技术试题及答案解析(11页珍藏版)》请在人人文库网上搜索。1、精品自学考试资料推荐全国 2018年 1月自考微型计算机及其接口技术试题课程代码…

16-djongo中间件学习

目录 前戏 我们在前面的课程中已经学会了给视图函数加装饰器来判断是用户是否登录&#xff0c;把没有登录的用户请求跳转到登录页面。我们通过给几个特定视图函数加装饰器实现了这个需求。但是以后添加的视图函数可能也需要加上装饰器&#xff0c;这样是不是稍微有点繁琐。 学完…