使用 JS 实现图片左右跑马灯
Ø 前言
之前写了一篇使用 JS 实现文字上下跑马灯,现在乘热打铁在把图片左右跑马灯一起贴出来,不多说直接看代码。
1. 首先定义 css 样式
<style type="text/css">
*{
margin: 0px;
padding: 0px;
list-style: none;
}
#div1{
width: 500px;
height: 125px;
margin: 60px auto 0px auto;
border: 2px solid lightgreen;
position: relative;
overflow: hidden;
}
#ul_img{
position: absolute;
top: 0;
left: 0;
}
#ul_img li{
float: left;
width: 125px;
height: 125px;
/*border: 1px solid red;*/
}
#ul_img li img{
width: 100%;
height: 100%;
}
</style>
2. HTML 代码
<div id="div1">
<ul id="ul_img">
<li><img src="../../../../Images/301.jpg" alt=""/></li>
<li><img src="../../../../Images/201.jpg" alt=""/></li>
<li><img src="../../../../Images/302.gif" alt=""/></li>
<li><img src="../../../../Images/202.jpg" alt=""/></li>
<li><img src="../../../../Images/203.jpg" alt=""/></li>
</ul>
</div>
3. JS 代码
var millisec = 10; //滚动间隔时间(毫秒)
var intervalId;
var left = 0;
var ul;
window.onload = function(){
ul = document.getElementById("ul_img");
ul.innerHTML += ul.innerHTML; //复制一份相同的li
var lis = ul.getElementsByTagName("li");
ul.style.width = (lis[0].offsetWidth * lis.length) + "px"; //重新设置宽度
intervalId = setInterval("scroll()", millisec);
var div1 = document.getElementById("div1");
div1.onmouseover = function(){
clearInterval(intervalId);
}
div1.onmouseout = function(){
intervalId = setInterval("scroll()", millisec);
}
}
function scroll(){
left -= 1;
//定位小于等于总宽度的二分之一时,则left设置为0
if(left <= -ul.offsetWidth / 2)
left = 0;
ul.style.left = left + "px";
}
4. 运行效果

Ø 分析
1. 总体来说还是比较简单,首先定义了一个 div,并在内部定义了 ul li 标签,用于存放图片。
2. 再将 ul 标签绝对定位,li 标签左浮动,img 宽度与高度设置100%。
3. js 运行时,首先复制一份所有的 li 标签,加入 ul 中(用于滚动时的下一份图片集合)。
4. 在 js 中可以看到,当ul 的 left 值小于 ul.offsetWidth 的二分之一时,就重新定位 ul 标签,这样就实现了循环滚动。
使用 JS 实现图片左右跑马灯的更多相关文章
- 使用vue.js封装一个包含图片的跑马灯组件
初衷: 学习完Vuejs后,来准备练习仿写一下老东家的门户页面,主要是为了熟悉一下常用插件的使用,比如video.js,wow.js,swiper等等:而其中涉及到一个包含图片跑马灯组件,大概长这样( ...
- 使用 JS 实现文字左右跑马灯
Ø 前言 其实,前面两篇已经基本上实现了图片.文字跑马灯,这里为什么还要学下文字左右跑马灯呢?因为,虽然基本一样,但实现起来还是有很大不同的,所以为了完整再补充一下.代码如下: 1. 首先定义 ...
- 【HTML】 向网页<Title></Title>中插入图片以及跑马灯
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <style typ ...
- 使用 JS 实现文字上下跑马灯
Ø 前言 今天在做商城首页时,遇到一个上下跑马灯功能,因为之前也只是接触过左右的跑马灯,一时还不知道从何下手.在网上看了几个 demo,并亲自运行了一下,是可以实现的.但是,能运行不知其所以然也不行 ...
- JS写一个列表跑马灯效果--基于touchslide.js
先放上效果图: 类似于这样的,在列表中循环添加背景样式的跑马灯效果. 准备引入JS插件: <script type="text/javascript" src="x ...
- jquery.marquee.js - 有点奇怪的跑马灯动画,不过还是加上去了
客户想要一个跑马灯的效果,最终我用了jquery.marquee.js. 这个库很简单就能用. 效果是这样,从左到右,移动速度都不一样. 1. HTML <div class="mar ...
- PS跑马灯效果和更换图标
最终效果 1.图片修改 跑马灯效果图 Head页面 使用的 IScript_HPDefaultHdr() in WEBLIB_PORTAL.PORTAL_HOMEPAGE 这个页面 一 ...
- 微信小程序里实现跑马灯效果
在微信小程序 里实现跑马灯效果,类似滚动字幕或者滚动广告之类的,使用简单的CSS样式控制,没用到JS wxml: <!-- 复制的跑马灯效果 --> <view class=&quo ...
- javascript小记五则:用JS写一个图片左右自由滚动的“跑马灯”效果
之前看了很多百度搜索出的东西,十个有九个是不能实用的,个个讲的都不详细,今天详细给大家讲解下关于这个图片“跑马灯”滚动效果,源码如下: <!DOCTYPE html PUBLIC "- ...
随机推荐
- BZOJ3029守卫者的挑战(概率dp)
题目大意:给定n个事件,第i个事件发生的概率为pi,收益为ai,初始收益为k,求n个事件之后发生的事件数>=l且收益>=0的概率 收益只可能是正整数或-1. Solution dp[i][ ...
- HDU5758 Explorer Bo 思维+树形dp
题意自己看题目吧,挺短的. 思考过程:昨天感觉一天不做题很对不起自己,于是晚上跑到实验室打开别人树形dp的博客做了上面最后一个HDU的题,也是个多校题..一开始没有头绪了很久,因为起点不固定,所以这1 ...
- A1118. Birds in Forest
Some scientists took pictures of thousands of birds in a forest. Assume that all the birds appear in ...
- c语言: 生成随机数
#include <time.h> srand((unsigned)time(NULL)); for(int i=0;i<10;i++) { //printf("%d\n& ...
- django基于中间件的IP访问频率控制
一.中间件的代码 注意:成功时返回的是None,那样才会走视图层,返回httpresponse就直接出去了 import time from django.utils.deprecation impo ...
- HomeFragment 嵌套关系
1.HomeFragment 在mainActivty 中调用: 2.HomeFragment 中: private ArrayList<Fragment> mFragments = ne ...
- linux 进程创建clone、fork与vfork
目录: 1.clone.fork与vfork介绍 2.fork说明 3.vfork说明 4.clone说明5.fork,vfork,clone的区别 内容: 1.clone.fork与vfork介绍 ...
- 信用评分卡 (part 4 of 7)
python信用评分卡(附代码,博主录制) https://study.163.com/course/introduction.htm?courseId=1005214003&utm_camp ...
- Tensorflow object detection API 搭建物体识别模型(三)
三.模型训练 1)错误一: 在桌面的目标检测文件夹中打开cmd,即在路径中输入cmd后按Enter键运行.在cmd中运行命令: python /your_path/models-master/rese ...
- plus初始化原理及plus is not defined,mui is not defined 错误汇总
原文 关于plus是哪里来的问题 plus是5+Runtime的内部对象.就像chrome浏览器里有chrome.开头的一些对象方法,5+runtime内部内置了plus对象.因为plus和mui不一 ...