Ø  前言

之前写了一篇使用 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 实现图片左右跑马灯的更多相关文章

  1. 使用vue.js封装一个包含图片的跑马灯组件

    初衷: 学习完Vuejs后,来准备练习仿写一下老东家的门户页面,主要是为了熟悉一下常用插件的使用,比如video.js,wow.js,swiper等等:而其中涉及到一个包含图片跑马灯组件,大概长这样( ...

  2. 使用 JS 实现文字左右跑马灯

    Ø  前言 其实,前面两篇已经基本上实现了图片.文字跑马灯,这里为什么还要学下文字左右跑马灯呢?因为,虽然基本一样,但实现起来还是有很大不同的,所以为了完整再补充一下.代码如下: 1.   首先定义 ...

  3. 【HTML】 向网页<Title></Title>中插入图片以及跑马灯

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <style typ ...

  4. 使用 JS 实现文字上下跑马灯

    Ø  前言 今天在做商城首页时,遇到一个上下跑马灯功能,因为之前也只是接触过左右的跑马灯,一时还不知道从何下手.在网上看了几个 demo,并亲自运行了一下,是可以实现的.但是,能运行不知其所以然也不行 ...

  5. JS写一个列表跑马灯效果--基于touchslide.js

    先放上效果图: 类似于这样的,在列表中循环添加背景样式的跑马灯效果. 准备引入JS插件: <script type="text/javascript" src="x ...

  6. jquery.marquee.js - 有点奇怪的跑马灯动画,不过还是加上去了

    客户想要一个跑马灯的效果,最终我用了jquery.marquee.js. 这个库很简单就能用. 效果是这样,从左到右,移动速度都不一样. 1. HTML <div class="mar ...

  7. PS跑马灯效果和更换图标

    最终效果     1.图片修改   跑马灯效果图 Head页面 使用的 IScript_HPDefaultHdr() in WEBLIB_PORTAL.PORTAL_HOMEPAGE 这个页面   一 ...

  8. 微信小程序里实现跑马灯效果

    在微信小程序 里实现跑马灯效果,类似滚动字幕或者滚动广告之类的,使用简单的CSS样式控制,没用到JS wxml: <!-- 复制的跑马灯效果 --> <view class=&quo ...

  9. javascript小记五则:用JS写一个图片左右自由滚动的“跑马灯”效果

    之前看了很多百度搜索出的东西,十个有九个是不能实用的,个个讲的都不详细,今天详细给大家讲解下关于这个图片“跑马灯”滚动效果,源码如下: <!DOCTYPE html PUBLIC "- ...

随机推荐

  1. table用模板生成的问题

    在使用<template></template>存放HTML模板标记时,发现一个烦人的问题,表格不行. <template> <table> <t ...

  2. css图片替换文字

    含义: 图像替代,就是像我们在平时将文本添加到文本中,然后通过css隐藏文本在它的位置上显示一个背景图片,这样,搜索引擎仍然可以搜到HTML文本,即使我们禁用css后,文本时仍然是可以显示的. 引用& ...

  3. 51nod 1443 路径和树(最短路树)

    题目链接:路径和树 题意:给定无向带权连通图,求从u开始边权和最小的最短路树,输出最小边权和. 题解:构造出最短路树,把存留下来的边权全部加起来.(跑dijkstra的时候松弛加上$ < $变成 ...

  4. Thinkphp5 captcha扩展包安装,验证码验证以及点击刷新

    首先下载 captcha扩展包,↓ 下载附件,解压到vendor目录下: 然后进入application/config.php添加配置信息: //验证码       'captcha'  =>  ...

  5. 省市区三级数据的MYSQL内容

    省市区三级数据的MYSQL内容 省: /* Navicat MySQL Data Transfer Source Server : rm-2ze0lz594rof5nn72.mysql.rds.ali ...

  6. twitter api

    1,twurl安装 1.1,安装软件管理包工具,在管理员身份打开的cmd中执行: @"%SystemRoot%\System32\WindowsPowerShell\v1.0\powersh ...

  7. A1133. Splitting A Linked List

    Given a singly linked list, you are supposed to rearrange its elements so that all the negative valu ...

  8. Flask 应用上下文

    应用上下文(application context) 它的字面意思是 应用上下文,但它不是一直存在的,它只是request context 中的一个对 app 的代理(人),所谓local proxy ...

  9. 被addPropertyChangeListener("...",this)差点搞崩溃

    以前常用的是addPropertyChangeListener(this)方法 记得有一天我发现还有另一种写法: addPropertyChangeListener(String propertyNa ...

  10. 2018-2019 ACM-ICPC, Asia Nanjing Regional Contest

    https://codeforces.com/gym/101981 Problem A. Adrien and Austin 贪心,注意细节 f[x]=1:先手必赢. f[x]: 分成两部分(或一部分 ...