自己写的一个banner动画
html
<div class="nav" >
<div class="nav_son" id="nav">
<div class="nav_cont img_1">
<div class="nav_img "><img src="data:images/001_03.png" width="" height="" /></div>
</div>
<div class="nav_cont img_2">
<div class="nav_img "><img src="data:images/001_05.png" width="" height="" /></div>
</div>
<div class="nav_cont img_3">
<div class="nav_img"><img src="data:images/banner1_01.png" width="" height="" /></div>
</div>
<div class="nav_cont img_4">
<div class="nav_img"><img src="data:images/nav005_03.png" width="" height="" /></div>
</div>
</div>
<div class="nav_but">
<ul class="nav_but_ul" id="butUl">
<li class="check"></li>
<li></li>
<li></li>
<li></li>
</ul>
</div>
</div>
css
*{ margin:; padding:;}
ul ,li { list-style:none;}
.nav {
height: 525px;
width: 100%;
position:relative;
overflow:hidden; }
.nav_cont {
background-repeat: no-repeat;
background-position: center top;
position:absolute;
top:0px;
width:100%; height:100%;
left:-100%;
} .nav_son {width: 100%; height:100%; position:absolute;left:100%; }
.img_1 { background-image:url(images/003_006bg.jpg)}
.img_2 { background-image:url(images/003_005bg.jpg)}
.img_3 { background-image:url(images/banner1.jpg)}
.img_4 { background-image:url(images/nav005.jpg)}
.nav_img { position:absolute; left:50%; margin-left:-600px; }
.nav .nav_but {
width: 100%;
position: absolute;
bottom: 10px;
z-index:;
}
.nav_but_ul { overflow:auto; width:120px; margin:0 auto;height: 20px;}
.nav_but_ul li { float:left; width:14px; height:14px; background:url(images/1CdeO2mZF63.PNG); text-indent:-9999px; cursor:pointer; margin-right:5px ;background-position:-14px 0px;}
.nav_but_ul li.check { background-position:0px 0px;}
js
var nav = document.getElementById("nav");
var list = document.querySelectorAll("#nav>div");
var nowNum = 0 ;
var start = 4 ;
var butList = document.querySelectorAll("#butUl>li");
var timer = null;
window.onload = function (){
list[nowNum].style.zIndex = 9 ; for (var i=0; i<butList.length;i++){
butList[i].setAttribute("index",i);
}
isAddEvent(1);
setTimeout(init,7000)
} ;
function func (e){
e = e || window.event ;
if(e.target){ var ele = e.target}
else if (e.srcElement){
var ele = e.srcElement
}
var num = parseInt( ele.getAttribute("index")); init(num);
}
function init(num){
if(num != null){
goImg =num ;
if (goImg == nowNum ){
return ;
}
}
else {
goImg = nowNum+1 ; }
if(goImg == 4){goImg= 0 ;}
list[goImg].style.left = "0px";
move(goImg);
if(timer){clearTimeout(timer);timer = setTimeout(init,7000); }
else {
timer = setTimeout(init,7000);
} } function isAddEvent (isBut){ for (var i=0; i<butList.length;i++){
if(isBut){listenEvent(butList[i],"click",func);}
else {stopListening(butList[i],"click",func);}
} } function move (goImg){ isAddEvent(0);
this.goImg = goImg;
var sonImg = list[nowNum].getElementsByTagName("div")[0];
var sonNowPos = GetCurrentStyle(sonImg,"left");
var nex = /%$/g ;
var nowPosition = GetCurrentStyle(nav,"left"); if(nex.test(sonNowPos)){
sonNowPos = parseInt(sonNowPos)/100 * document.body.clientWidth;
} else { sonNowPos = parseInt(sonNowPos);}
if(nex.test(nowPosition)){
nowPosition =parseInt(nowPosition)/100 * document.body.clientWidth;
} else { nowPosition = parseInt(nowPosition);}
//console.log(nowNum,goImg);
var butList = document.querySelectorAll("#butUl>li"); for (var i=0; i<butList.length;i++){butList[i].className = "" }
butList[goImg].className = "check ";
start*= 1.5 ; sonNowPos =Math.floor(sonNowPos-start);
sonImg.style.left = sonNowPos+"px";
time = setTimeout("move(this.goImg)",100); if(sonNowPos<300){ nowPosition-=document.body.clientWidth/10;
nav.style.left = nowPosition+"px"; }
console.log(nowPosition);
if(nowPosition<=0){
nav.style.left = "100%"
sonImg.style.left = "50%";
sonImg.removeAttribute("style");
list[nowNum].style.zIndex = 0 ;
list[nowNum].removeAttribute("style");
list[goImg].removeAttribute("style");
list[goImg].style.zIndex = 9 ; nowNum = goImg;
start=4;
isAddEvent(1);
clearTimeout(time);
}
} // 侦听
function listenEvent(eventTarget,eventType,eventHandler){
if(eventTarget.addEventListener){
eventTarget.addEventListener(eventType,eventHandler)
}
else if (eventTarget.attachEvent){
eventType = "on" +eventType ;
eventTarget.attachEvent(eventType,eventHandler)
}
else {
eventTarget["on"+eventType]=eventHandler;
}
}
// 停止侦听
function stopListening(eventTarget,eventType,eventHandler){
if(eventTarget.removeEventListener){
eventTarget.removeEventListener(eventType,eventHandler);
}
else if (eventTarget.detachEvent){
eventType = "on" +eventType ;
eventTarget.detachEvent(eventType,eventHandler);
}
else {
eventTarget["on"+eventType]=null;
}
} //获得样式
function GetCurrentStyle (obj, prop)
{
if (obj.currentStyle) //IE
{
return obj.currentStyle[prop];
}
else if (window.getComputedStyle) //非IE
{
propprop = prop.replace (/([A-Z])/g, "-$1");
propprop = prop.toLowerCase ();
return document.defaultView.getComputedStyle(obj,null)[propprop];
}
return null;
}
ps:可能有点小BUG,但是我目前看不出来哪里出问题了。求高手解决。
自己写的一个banner动画的更多相关文章
- 用C3中的animation和transform写的一个模仿加载的时动画效果
用用C3中的animation和transform写的一个模仿加载的时动画效果! 不多说直接上代码; html标签部分 <div class="wrap"> <h ...
- C# WPF 低仿网易云音乐(PC)Banner动画控件
原文:C# WPF 低仿网易云音乐(PC)Banner动画控件 由于技术有限没能做到一模一样的动画,只是粗略地做了一下.动画有点生硬,还有就是没做出网易云音乐的立体感.代码非常简单粗暴,而且我也写有很 ...
- 如何在RCP程序中添加一个banner栏
前言:这段时间还算比较空闲,我准备把过去做过的有些形形色色,甚至有些奇怪的研究总结一下,也许刚好有人用的着也不一定,不枉为之抓耳挠腮的时光和浪费的电力.以前有个客户提出要在RCP程序中添加一个bann ...
- 原生js写的一个弧形菜单插件
弧形菜单是一种半弧式或者全弧形菜单,是一种不同于传统横向或者竖向菜单形式的菜单.最近在网上看到好多人写出了这种效果,于是也尝试自己写了一个. 实现方式:原生态js 主要结构: 1.参数合并 var d ...
- 开源自己写的一个拖拽库,兼容到IE8+
github地址:https://github.com/qiangzi7723/draggable 目前这个库的兼容做到了兼容IE8,所以如果需要兼容IE8的朋友不妨试试.库里面写了很多的注释,对于想 ...
- Android给ListView添加一个入场动画
动画是一个App体现良好交互的一种手段,通常的我们会看到很多App的ListView的Item都有一个入场动画例如: 可以看到,当进入界面加载ListView的Item的时候有一个向左滑动显示,并且淡 ...
- iOS-如何写好一个UITableView
如何写好一个UITableView 字数5787 阅读3745 评论25 喜欢69 本文是直播分享的简单文字整理,直播共分为上.下两部分.第一部分:优酷 Or YouTube,第二部分:优酷 Demo ...
- 用css3+js写了一个钟表
有一天看到css3旋转这个属性,突发奇想的写了一个钟表(没做浏览器兼容),来一起看看是怎么写的吧! 先给个成品图,最终结果是个样子的(动态的). 首先,思考了一下页面的布局,大致需要4层div,最底层 ...
- 写了一个迷你toast提示插件,支持自定义提示文字和显示时间
写了一个迷你toast提示插件,支持自定义提示文字和显示时间,不想用其他第三方的ui插件,又想要toast等小效果来完善交互的同学可以试试, 代码中还贡献了一段css能力检测js工具函数,做项目的时候 ...
随机推荐
- cognos启动报错
[ ERROR ] Content Manager is unable to process your request because an unexpected event occurred in ...
- WordPress Citizen Space插件跨站请求伪造漏洞
漏洞名称: WordPress Citizen Space插件跨站请求伪造漏洞 CNNVD编号: CNNVD-201307-463 发布时间: 2013-07-23 更新时间: 2013-07-23 ...
- 「Poetize8」Divisible
描述 Description 设F[i]为斐波那契数列的第i项,F[1]=1,F[2]=1,F[i]=F[i-1]+F[i-2](i>=3). 输入格式 InputFormat 输入包含若干行( ...
- C#调用Exe文件的方法及如何判断程序调用的exe已结束
很简单的代码就可以实现C#调用EXE文件,如下: 引入using System.Diagnostics; 调用代码: Process.Start(exe文件名); 或直接 System.Diagnos ...
- Android通过类对象的方式实现JSON数据的解析
1.通过主Activity的Button按钮实现数据的解析 public class MainActivity extends Activity { //定义一个包含Json格式的字符对象 priva ...
- [基础] 重载的时候什么时候用引用&
一般返回值还要继续被处理,而不仅仅是得到其值的时候,返回引用& 一般有[], =, ++, --, 还有输入输出运算符<<, >> Classtype &ope ...
- openStack 云平台管理节点管理网口流量非常大 出现丢包严重 终端总是时常中断问题调试及当前测试较有效方案
tuning for Data Transfer hosts connected at speeds of 1Gbps or higher <一.本次OpenStack系统调试简单过程简单记录& ...
- 存储的一些基本概念(HBA,LUN)
有些新手总是在各式各样的概念里绕来绕去,弄的不亦乐乎.所以我就把我的一些理解写了下来,供您参考.我说的不局限于任何一种具体产品和厂家,也可能有些说法和某些厂家的说法不一样,但是我觉得应该算的上是本原的 ...
- 转载:linux capability深入分析
转至http://www.cnblogs.com/iamfy/archive/2012/09/20/2694977.html 一)概述: 1)从2.1版开始,Linux内核有了能力(capabili ...
- bootstrap 仿实例
bootstrap实现一个网页 html文件 <!DOCTYPE html> <html> <head lang="en"> <meta ...