javascript 简单抽屉效果的实现代码


Posted in Javascript onMarch 09, 2010

css

<style type="text/css"> 
#bodycontainer 
{ 
height: 66px; 
} 
#leftcontainer 
{ 
background-color: #C5C5C5; 
float: left; 
border: 1px solid #C5C5C5; 
} 
</style>

aspx:
<div id="bodycontainer"> 
<div id="leftcontainer+<%#Container.ItemIndex+1 %>" style="display:none;"> 
<%#hiSoft.AMS.BLL.BAssetAlteration.getActionLinksString(Eval("ID"), g_Sites, g_Permission)%> 
</div> 
<div> 
<img title="show" alt="open" src="Images/x16.gif" id="showleft+<%#Container.ItemIndex+1 %>" onclick="var leftslider = new slider(this,1,50,85,20,1,20);leftslider.show();this.style.display='none';Show(this);"/> 
<script type="text/javascript"> 
function Show(a) { 
//a.style.display = 'none'; 
document.getElementById(a.parentElement.children[2].id).style.display = ''; 
} 
</script> 
<img title="hidden" alt="close" src="Images/x16.gif" id="hideleft+<%#Container.ItemIndex+1 %>" onclick="var leftslider = new slider(this,1,50,85,20,1,20);leftslider.hide();this.style.display='none';document.getElementById(this.parentElement.children[0].id).style.display='';" style="display:none " /> 
</div> 
</div> 
 

slider.js:
slider.names = new Array(); 
function slider() 
{ 
this.id = slider.names.length; 
slider.names[this.id] = this; 
this.target = document.getElementById(arguments[0].parentElement.parentElement.children[0].id); //第一个参数:被操作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";} //循环完毕,清除循环定时 
}
Javascript 相关文章推荐
分享一个asp.net pager分页控件
Jan 04 Javascript
js实现的GridView即表头固定表体有滚动条且可滚动
Feb 19 Javascript
详细分析单线程JS执行问题
Nov 22 Javascript
vue-cli启动本地服务局域网不能访问的原因分析
Jan 22 Javascript
vue中Element-ui 输入银行账号每四位加一个空格的实现代码
Sep 14 Javascript
详解Vue-axios 设置请求头问题
Dec 06 Javascript
vue.js使用v-model实现表单元素(input) 双向数据绑定功能示例
Mar 08 Javascript
详解element-ui日期时间选择器的日期格式化问题
Apr 08 Javascript
js实现for循环跳过undefined值示例
Jul 02 Javascript
jQuery 筛选器简单操作示例
Oct 02 jQuery
JavaScript 正则应用详解【模式、欲查、反向引用等】
May 13 Javascript
Vue 实现创建全局组件,并且使用Vue.use() 载入方式
Aug 11 Javascript
Javascript常考语句107条收集
Mar 09 #Javascript
风吟的小型JavaScirpt库 (FY.JS).
Mar 09 #Javascript
Jquery实现无刷新DropDownList联动实现代码
Mar 08 #Javascript
JavaScript this调用规则说明
Mar 08 #Javascript
javascript 放大镜 v1.0 基于Yui2 实现的放大镜效果
Mar 08 #Javascript
JavaScript中的闭包原理分析
Mar 08 #Javascript
ExtJS GridPanel 根据条件改变字体颜色
Mar 08 #Javascript
You might like
PHP4 与 MySQL 交互使用
2006/10/09 PHP
PHP使用CURL获取302跳转后的地址实例
2014/05/04 PHP
PHP+jQuery 注册模块开发详解
2014/10/14 PHP
php判断文件上传类型及过滤不安全数据的方法
2014/12/17 PHP
Codeigniter检测表单post数据的方法
2015/03/21 PHP
php cookie工作原理与实例详解
2016/07/18 PHP
使用TextRange获取输入框中光标的位
2006/10/14 Javascript
javascript单引号和双引号的区别和处理
2014/05/14 Javascript
js显示文本框提示文字的方法
2015/05/07 Javascript
一个炫酷的Bootstrap导航菜单
2016/12/28 Javascript
jquery中done和then的区别(详解)
2017/12/19 jQuery
JQueryDOM之样式操作
2019/03/27 jQuery
JavaScript多种页面刷新方法小结
2019/04/04 Javascript
微信小程序 授权登录详解(附完整源码)
2019/08/23 Javascript
JS实现滚动条触底加载更多
2019/09/19 Javascript
在Python程序中操作文件之flush()方法的使用教程
2015/05/24 Python
python实现应用程序在右键菜单中添加打开方式功能
2017/01/09 Python
深入理解python中的select模块
2017/04/23 Python
用Python写一段用户登录的程序代码
2018/04/22 Python
Python3.遍历某文件夹提取特定文件名的实例
2018/04/26 Python
Python使用pickle模块实现序列化功能示例
2018/07/13 Python
用python求一个数组的和与平均值的实现方法
2019/06/29 Python
Python使用Pandas库实现MySQL数据库的读写
2019/07/06 Python
numpy中生成随机数的几种常用函数(小结)
2020/08/18 Python
python如何实现图片压缩
2020/09/11 Python
lululemon美国官网:瑜伽服+跑步装备
2018/11/16 全球购物
向国旗敬礼活动总结范文2014
2014/09/27 职场文书
公司感恩节活动策划书
2014/10/11 职场文书
2015年党员干部承诺书
2015/01/21 职场文书
国庆阅兵观后感
2015/06/15 职场文书
无犯罪记录证明样本
2015/06/16 职场文书
三年级作文之趣事作文
2019/11/04 职场文书
2021-4-3课程——SQL Server查询【2】
2021/04/05 SQL Server
mysql 带多个条件的查询方式
2021/06/05 MySQL
react使用antd的上传组件实现文件表单一起提交功能(完整代码)
2021/06/29 Javascript
据Python爬虫不靠谱预测可知今年双十一销售额将超过6000亿元
2021/11/11 Python