<!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>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>滑動效果類</title>
<STYLE>
body {
background-color: #EEEEEE;
margin: 0px;
text-align: center;
}
#wrap {
width: 736px;
background-color: #FFFFFF;
overflow: hidden;
margin: 12px;
padding: 12px;
}
#topcontainer {
height: 80px;
width: 732px;
background-color: #99FF66;
border: 1px solid #79F200;
}
#bodycontainer {
height: 400px;
width: 100%;
margin-top: 12px;
}
#bottomcontainer {
height: 60px;
width: 100%;
margin-top: 12px;
}
#topwrap {
width: 100%;
}
#leftcontainer {
background-color: #99FF66;
height: 400px;
width: 120px;
float: left;
border: 1px solid #79F200;
}
input {
background-color: #99FF66;
border-top-width: 1px;
border-right-width: 1px;
border-bottom-width: 1px;
border-left-width: 1px;
border-top-style: solid;
border-right-style: solid;
border-bottom-style: solid;
border-left-style: solid;
border-top-color: #79F200;
border-right-color: #79F200;
border-bottom-color: #79F200;
border-left-color: #79F200;
line-height: 28px;
background-position: center;
height: 30px;
}
</STYLE>
</head>
<body>
<br />
<div id="wrap">
<div align="left" style="margin-bottom:3px" mce_style="margin-bottom:3px">
<input type="button" id="showtop" οnclick="topslider.show();this.style.display='none';document.getElementById('hidetop').style.display='';" value="展開頂部"/>
<input type="button" id="hidetop" value="關閉頂部" οnclick="topslider.hide();this.style.display='none';document.getElementById('showtop').style.display='';" style="display:none" mce_style="display:none"/>
</div>
<div id="topwrap">
<div id="topcontainer" style="display:none" mce_style="display:none"></div>
</div>
<div id="bodycontainer">
<div id="leftcontainer" style="display:none" mce_style="display:none"><br />
<br />
<br />
</div>
<div align="left">
<input type="button" id="showleft" value="展開左側" οnclick="leftslider.show();this.style.display='none';document.getElementById('hideleft').style.display='';"/>
<input type="button" id="hideleft" value="關閉左側" οnclick="leftslider.hide();this.style.display='none';document.getElementById('showleft').style.display='';" style="display:none" mce_style="display:none"/>
</div>
</div>
<div id="bottomcontainer"></div>
</div>
<script language="JavaScript" type="text/javascript"><!--
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初始化的順序
// --></script>
</body>
</html>
<!--
Slider類的功能說明:?、可以控制任何一個頁面上存在的div?、slider在滑動的同時還可以實現透明度的變化,整個過程更平滑、更美觀…、可控性強,通過多個參數實現不同大小的div不同方向、不同速度的滑動?、調用方便,一句話即可初始化,slider的隱現控制更爲簡單,詳情參見代碼例子
Slider類的調用說明:
//關於如何使用這個代碼的說明:
//上面的代碼可以封裝成爲一個單獨的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初始化的順序
-->
div 滑動展開效果
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.