实现图片的循环滚动——JS的简单应用
首先默认都了解JS的循环分支运算符等基本语法
用CSS实现简单的布局也是会的。
然后我们就可以来了解一下
function getById(){
//取到属性节点
// var divById = document.getElementById("div1").style;
//取到元素节点
var divById = document.getElementById("div1");
//divById.style.backgroundColor = "blueviolet";//节点属性用小驼峰命名
divById.style.color="green";
divById.innerHTML="<h5>cherishLi</h5>";//重置修改div里的中的HTML代码
if(divById.style.backgroundColor == "blue"){
divById.style.backgroundColor = "red";
}
else{
divById.style.backgroundColor = "blue";
}
一个windows常用的方法我么这里也能用到,而且是最关键的,那就是设置定时器
var out=setInterval(function(){
document.write(num+"<br/>");
num--;
if(num==0){
clearInterval(out);
}
},1000)
还有两个很关键的属性,我们要用到:
<section id="banner">
<div id="inside">
<img src="../img/12168431_1036060226444795_851404817_o_z1lzd7.jpg"/>
<img src="../img/12388071_1065320530185431_2076280306_n_g93ygx.jpg"/>
<img src="../img/12656432_1094243637293120_49905962_o_dk24or.jpg"/>
<img src="../img/12903800_1136073019776848_60542799_o_rewsfx.jpg"/>
<img src="../img/12910198_1136068819777268_2019684994_n_shntwd.jpg"/>
</div> </section>
然后设置一下样式(如何在只能显示四张图的区域放下十张图)
*{
margin: 0px;
padding: 0px;
}
#banner{
width: 440px;
height: 110px;
overflow: hidden;
white-space: nowrap;
}
#inside{
width: 1100px;
height: 110px;
position: relative;
white-space: nowrap;
transition: all 0.5s ease;
}
#inside img{
float: left;
}
最后是JS代码,应该已经很明了了。每隔1s滚动100px,滚完5张,计数器清零。
var manyImg= document.getElementById("inside");
manyImg.innerHTML=manyImg.innerHTML+manyImg.innerHTML;
// console.log(manyImg.innerHTML=manyImg.innerHTML+manyImg.innerHTML);
var i=0;
var gun = setInterval(function(){
i++;
manyImg.style.transition="all 0.5s ease";
switch (i){
case 1:
manyImg.style.transition="none";
inside.style.marginLeft = 0+"px";
break;
case 2:
inside.style.marginLeft = (-110)+"px";
break;
case 3:
inside.style.marginLeft = (-110-110)+"px";
break;
case 4:
inside.style.marginLeft = (-110-110*2)+"px";
break;
case 5:
inside.style.marginLeft = (-110-110*3)+"px";
break;
case 6:
inside.style.marginLeft = (-110-110*4)+"px"
i = 0;
break;
case 7:
inside.style.marginLeft = (-110-110*5)+"px";
break;
case 8:
inside.style.marginLeft = (-110-110*6)+"px";
break;
case 9:
inside.style.marginLeft = (-110-110*7)+"px";
break;
case 10:
inside.style.marginLeft = (-110-110*8)+"px";
break;
case 11:
inside.style.marginLeft = (-110-110*9)+"px";
break;
default:
break;
}
},1000)
如果需要加上数字按钮控制对应的图片,只需用ul或者div做好按钮,加上一个函数控制就行
<ul id="bannerNumber">
<li onclick="changeBan(1)">1</li>
<li onclick="changeBan(2)">2</li>
<li onclick="changeBan(3)">3</li>
<li onclick="changeBan(4)">4</li>
</ul>
function changeBan(num1){
switch(num1){
case 1:
inside.style.marginLeft = 0+"px";
break;
case 2:
inside.style.marginLeft = (-110)+"px";
break;
case 3:
inside.style.marginLeft = (-110-110)+"px";
break;
case 4:
inside.style.marginLeft = (-110-110*2)+"px";
break;
case 5:
inside.style.marginLeft = (-110-110*3)+"px";
break;
}
i=num1-1;
}
效果可以自己实践一下=。=,这里就不插图了
实现图片的循环滚动——JS的简单应用的更多相关文章
- APP中常见上下循环滚动通知的简单实现,点击可进入详情
APP中常见上下循环滚动通知的简单实现,点击可进入详情 关注finddreams博客,一起分享一起进步!http://blog.csdn.net/finddreams/article/details/ ...
- 封装一个ViewPager真正的实现图片无限循环滚动带导航点
效果图: 大家在写项目的过程中常常会碰到须要实现Viewpager里面载入几张图片来循环自己主动轮播的效果,假设不封装一下的话代码分散在activity里面会显得非常乱.并且也不利于我们下次复用,所以 ...
- cocos2d(背景图片循环滚动)
背景图片循环滚动 使用action 实现的: 主要有两个背景图片交替循环滚动:我选的两个背景图片的宽度都是1024的 ,所以定义了#define BGIMG_WIDTH 1024 代码如下: 在Hel ...
- IOS实现自动循环滚动广告--ScrollView的优化和封装
一.问题分析 在许多App中,我们都会见到循环滚动的视图,比如广告,其实想实现这个功能并不难,用ScrollView就可以轻松完成,但是在制作的过程中还存在几个小问题,如果能够正确的处理好这些小问题, ...
- JavaScript学习笔记——简单无缝循环滚动展示图片的实现
今天做了一个简单的无缝循环滚动的实例,这种实例在网页中其实还挺常见的,下面分享一下我的学习收获. 首先,无缝滚动的第一个重点就是——动.关于怎么让页面的元素节点动起来,这就得学明白关于JavaScri ...
- jQuery图片无缝滚动JS代码ul/li结构
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- js 实现图片间隔循环轮播以及没有间隔的循环轮播
链接地址:http://blog.sina.com.cn/s/blog_75cf5f32010199dn.html 最近做了个图片循环轮播的功能.就是几张图片不断的循环滚动显示. 感觉这个方法不错所以 ...
- javascript小记五则:用JS写一个图片左右自由滚动的“跑马灯”效果
之前看了很多百度搜索出的东西,十个有九个是不能实用的,个个讲的都不详细,今天详细给大家讲解下关于这个图片“跑马灯”滚动效果,源码如下: <!DOCTYPE html PUBLIC "- ...
- JS仿QQ空间鼠标停在长图片时候图片自动上下滚动效果
JS仿QQ空间鼠标停在长图片时候图片自动上下滚动效果 今天是2014年第一篇博客是关于类似于我们的qq空间长图片展示效果,因为一张很长的图片不可能全部把他展示出来,所以外层用了一个容器给他一个高度,超 ...
随机推荐
- 卸载php+apache+mysql
一.卸载删除 mysql 1 sudo apt-get autoremove --purge mysql-server-5.0 2 sudo apt-get remove mysql-server ...
- postman定义公共函数
对于postman定义公共函数,相信很多小伙伴并不是很了解,下面给大家带来了一点福利,一起来看看吧.1.判断是否超时(assertNotTimeout)
- Struts2的validator和WEB-INF下页面交互以及路径问题
当我使用短路校验器时(客户端),在页面下方老是出来 FreeMarker template error!然后我就把我的页面都放在了WEB-INF中,结果很多路径都不对了,因为客户端是没有直接访问Str ...
- 使用MyBatis对数据库中表实现CRUD操作(二)
一.使用MyBatis对表实现CRUD操作 1.定义sql映射 userMapper.xml <?xml version="1.0" encoding="UTF-8 ...
- Unity 3D Framework Designing(4)——设计可复用的SubView和SubViewModel(Part 1)
『可复用』这个词相信大家都熟悉,通过『可复用』的组件,可以大大提高软件开发效率. 值得注意的事,当我们设计一个可复用的面向对象组件时,需要保证其独立性,也就是我们熟知的『高内聚,低耦合』原则. 组件化 ...
- 数据库DQL操作(重点)
*****DQL -- 数据查询语言 查询不会修改数据库表记录!一. 基本查询//emp表名1. 字段(列)控制1) 查询所有列 SELECT * FROM 表名; SELECT * FROM em ...
- Unity 3D Framework Designing(7)——IoC工厂理念先行
一谈到 『IoC』,有经验的程序员马上会联想到控制反转,将创建对象的责任反转给工厂.IoC是依赖注入 『DI』 的核心,大名鼎鼎的Spring框架就是一个非常卓越的的控制反转.依赖注入框架.遗憾的是, ...
- JSTL标签用法 详解(转)
JSTL 核心标签库标签共有13个,功能上分为4类: 1.表达式控制标签:out.set.remove.catch 2.流程控制标签:if.choose.when.otherwise 3.循环标签:f ...
- 20155206 2016-2017-2 《Java程序设计》第5周学习总结
20155206 2016-2017-2 <Java程序设计>第5周学习总结 教材学习内容总结 Java中所有错误都会被打包为对象,运用try.catch,可以在错误发生时显示友好的错误信 ...
- webpack点滴记录
有了webpack..(不借助gulp/grunt)代码压缩 图片base64,解析less/sass coffee css压缩,MD5加密都帮你做了..还支持按需加载..还有热替换 webpack常 ...