DIV滑动效果

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
<script type="text/javascript" src="slip.js"></script>
 <script type="text/javascript">


function showcontent(){

//alert(topslider);
topslider.show();

setTimeout ('hidecontent()',1000);
}
function hidecontent()
{
topslider.hide();
setTimeout ('show2content()',500);

}
function show2content()
{

leftslider.show();
}
 </script>
</head>
<body οnlοad="showcontent();">

                    <div id="adBig" style="display:none"><img title=VANCL购物全场免运费
                    src="free_980_1.gif"
                     border=0></div>
                   
                    <div id="adSmall" style="display:none"><img
                    title=VANCL购物全场免运费
                    src="free_980_2.gif"
                    border=0></div>


<script language="JavaScript" type="text/javascript">
var topslider = new slider('adBig',2,500,980,30,2,100);
var leftslider = new slider('adSmall',2,60,980,40,2,100);
</script>


</body>
</html>

slip.js:


slider.names = new Array();

function slider()
{
this.id = slider.names.length;
slider.names[this.id] = this;
this.target = document.getElementById(arguments[0]); //第一个参数:被操作div的id
this.direction = arguments[1];//第二个参数:div弹出的方向
this.height = arguments[2];//第三个参数:div的高度
this.width = arguments[3];//第四个参数:div的宽度
this.step = arguments[4];//第五个参数:希望动作分解为几步完成
this.timer = 10 * arguments[5];//第六个参数:每个动作的间隔时间,10ms为一个单位
this.startopa = arguments[6];//第七个参数:div开始的透明度
this.sparent = this.target.parentNode;//获取操作div的父容器
this.intervalid = null;//循环定时的id
this.i = 0;//循环的计数器
this.status = 0;//slider层的状态:0-可以展开;1-不可以展开
this.target.style.display = "none";//先将div隐去
return this;
}
slider.prototype.initialize = function()
{
this.sparent.style.overflow = "hidden";//设置父容器overflow
this.target.style.width = Number(this.width) + 'px';//设置目标div的宽度
this.target.style.height = Number(this.height) + 'px';//设置目标div的高度
this.target.style.position = "";//设置目标div的定位方式
this.target.style.display = "";//设置目标div的显示方式
this.target.style.filter = 'Alpha(opacity=' + Number(this.startopa) + ')';//设置目标div的透明度为初始透明度
this.target.style.overflow = "hidden";//设置overflow
switch(this.direction)//根据弹出方向设定div的margin
{
   case 1://left to right
    this.target.style.marginLeft = "-" + this.width + "px";
    break;
   case 2://top to bottom
    this.target.style.marginTop = "-" + this.height + "px";
    break;
   case 3://right to left
    this.target.style.marginRight = "-" + this.width + "px";
    break;
}
}
slider.prototype.show = function()
{
if (this.status==0)//检查状态是否已经展开
{
   this.initialize();//操作div及其父容器的初始化
   this.intervalid = window.setInterval("slider.names["+this.id+"].cycle()",this.timer);//设置动作循环
}
}
slider.prototype.hide = function()
{
if (this.status==1)//检查状态是否已经展开
{
   this.intervalid = window.setInterval("slider.names["+this.id+"].decycle()",this.timer);//设置动作循环
}
}
slider.prototype.cycle = function() //单步循环动作
{
var opa = this.target.style.filter.split("=")[1].split(")")[0]//获取目标div的透明度数值
var opastep = Math.round(((100 - Number(opa)) / this.step)+2.5);//计算每步增加的透明度
var nopa = Number(opa) + Number(opastep);//当前透明度
if (nopa>100){this.target.style.filter = 'Alpha(opacity=100)';}else{this.target.style.filter = 'Alpha(opacity=' + String(nopa) + ')';}//给div透明度赋值
switch(this.direction)//根据弹出方向计算和设定div的动作
{
   case 1:   //left to right
    var opx = this.target.style.marginLeft.split("px")[0];
    var pxstep = Math.round((this.width / this.step)+0.5);
    var npx = Number(opx) + Number(pxstep);
    if (npx>0){this.target.style.marginLeft = '0px';}else{this.target.style.marginLeft = String(npx) + 'px';}
    break;
   case 2:   //top to bottom
    var opx = this.target.style.marginTop.split("px")[0];
    var pxstep = Math.round((this.height / this.step)+0.5);
    var npx = Number(opx) + Number(pxstep);
    if (npx>0){this.target.style.marginTop = '0px';}else{this.target.style.marginTop = String(npx) + 'px';}
    break;
   case 3:   //right to left
    var opx = this.target.style.marginRight.split("px")[0];
    var pxstep = Math.round((this.width / this.step)+0.5);
    var npx = Number(opx) + Number(pxstep);
    if (npx>0){this.target.style.marginRight = '0px';}else{this.target.style.marginRight = String(npx) + 'px';}
    break;
}
this.i++ //计数器+1
if (this.i>(this.step-1)){window.clearInterval(this.intervalid);this.i=0;this.status=1;} //循环完毕,清除循环定时
}
slider.prototype.decycle = function() //单步循环动作
{
var opa = this.target.style.filter.split("=")[1].split(")")[0]//获取目标div的透明度数值
var opastep = Math.round(((100 - Number(opa)) / this.step)+2.5)*2;//计算每步增加的透明度
var nopa = Number(opa) - Number(opastep);//当前透明度
if (nopa<this.startopa){this.target.style.filter = 'Alpha(opacity=' + this.startopa + ')';}else{this.target.style.filter = 'Alpha(opacity=' + String(nopa) + ')';}//给div透明度赋值
switch(this.direction)//根据弹出方向计算和设定div的动作
{
   case 1:   //left to right
    var opx = this.target.style.marginLeft.split("px")[0];
    var pxstep = Math.round((this.width / Math.round(this.step*0.5))+0.5);
    var npx = Number(opx) - Number(pxstep);
    if (Math.abs(npx)>this.width+2){this.target.style.marginLeft = '-' + this.width + 'px';}else{this.target.style.marginLeft = String(npx) + 'px';}
    break;
   case 2:   //top to bottom
    var opx = this.target.style.marginTop.split("px")[0];
    var pxstep = Math.round((this.height / Math.round(this.step*0.5))+0.5);
    var npx = Number(opx) - Number(pxstep);
    if (Math.abs(npx)>this.height+2){this.target.style.marginTop = '-' + this.height + 'px';}else{this.target.style.marginTop = String(npx) + 'px';}
    break;
   case 3:   //right to left
    var opx = this.target.style.marginRight.split("px")[0];
    var pxstep = Math.round((this.width / Math.round(this.step*0.5))+0.5);
    var npx = Number(opx) - Number(pxstep);
    if (Math.abs(npx)>this.width+2){this.target.style.marginRight = '-' + this.width + 'px';}else{this.target.style.marginRight = String(npx) + 'px';}
    break;
}
this.i++ //计数器+1
if (this.i>(Math.round(this.step*0.5)-1)){window.clearInterval(this.intervalid);this.i=0;this.status=0;this.target.style.display = "none";} //循环完毕,清除循环定时
}
//关于如何使用这个代码的说明:
//上面的代码可以封装成为一个单独的js文件,然后包含在页面当中
//然后使用下面的代码进行slider初始化,一个页面可以使用多个slider,下面的代码必须在页面底部</body>之前,否则可能会报错
//var topslider = new slider('topcontainer',2,80,734,20,2,20);
//var leftslider = new slider('leftcontainer',1,398,120,20,1,20);
//参数分别代表的意义可以在代码顶端看到
//控制slider动作可以使用两种方式
//一种是使用下面声明的名字调用,比如topslider.show(),topslider.hide()
//另一种可以使用slider.names[0].show(),slider.names[0].hide(),下标取决于slider初始化的顺序

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值