js实现兼容IE和FF的上下层的移动


Posted in Javascript onMay 04, 2015

这里给大家分享的是项目中的一个小需求,本来很简单,可是整了好久才把FF的兼容性搞定。

<!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>仿265上下层的移动(上移,下移)支持IE、FF</title>
<style type="text/css">
/*<![CDATA[*/
ul{
width:400px
}
li{
border:1px solid gray;
list-style:none
}
.txt{
padding:4px;
background-color:#ffffff
}
/*]]>*/
</style>
<script language="javascript" type="text/javascript">
//<![CDATA
window.onload=function(){
ggGroup(document.getElementById('test'),5);
};
function ggGroup(ele,margin){
margin=margin||0;
var bgcolors='#b3d580,#99c9b1,#b4a1d8,#f7c480,#d5d588,#eea2bb'.split(',');
var txtUp='上移↑ ',txtDown='下移↓';
var panels=children(ele);
for(var i=0,h=0;i<panels.length;i++){
var p=panels[i];
p.style.position='absolute';
p.style.width='100%';
var b=document.createElement('div');
with(b.style){
fontSize='12px';
padding='4px';
backgroundColor=bgcolors[i%bgcolors.length];
textAlign='right';
}
b.innerHTML='<span>'+txtUp+'</span><span>'+txtDown+'</span>';
b.firstChild.onclick=moveup;
b.firstChild.style.cursor='pointer';
b.lastChild.onclick=movedown;
b.lastChild.style.cursor='pointer';
p.insertBefore(b,p.firstChild);
p.style.top=h+'px';
p.index=i;
h+=p.offsetHeight+margin;
}
ele.style.height=h+'px';
ele.style.position='relative'; 
check(0,i-1); 
function check(){
for(var i=0;i<arguments.length;i++){
var x=arguments[i];
var c=panels[x].firstChild.childNodes;
c[0].style.visibility=x==0?'hidden':'visible';
c[1].style.visibility=x==panels.length-1?'hidden':'visible';
panels[x].index=x;
}
}
function moveup(evt){
var p=evt?evt.target:event.srcElement;
p=p.parentNode.parentNode;
swap(p,panels[p.index-1]);
}
function movedown(evt){
var p=evt?evt.target:event.srcElement;
p=p.parentNode.parentNode;
swap(p,panels[p.index+1]);
}
function swap(p1,p2){
var N=10;
var INTV=200;
var arr1,arr2;
var t1=parseInt(p1.style.top),t2=parseInt(p2.style.top);
var h1=p1.offsetHeight+margin,h2=p2.offsetHeight+margin;
arr1=makeArr(t1,t1<t2?h2:-h2);
arr2=makeArr(t2,t1<t2?-h1:h1);
for(var i=0;i<N;i++)(function(){
var j=i;
setTimeout(function(){
p1.style.top=arr1[j]+"px";
p2.style.top=arr2[j]+"px";
if(j==N-1){
panels[p1.index]=p2;
panels[p2.index]=p1;
check(p1.index,p2.index);
}
},(j+1)*INTV/N);
})();
function makeArr(f,x){
var ret=[];
for(var i=0;i<N;i++)
ret[i]=Math.round(f+i*x/(N-1));
return ret;
}
}
function children(e){
var ret=[];
for(var i=0,c=e.childNodes;i<c.length;i++)
if(c[i].nodeType==1)
ret.push(c[i]);
return ret;
}
}
//]]>
</script>
</head>
<body>
<ul id="test">
<li> <div class="txt"><h2>Hello<br />baby</h2></div></li>
<li> <div class="txt">
显示内容1显示内容1显示内容1显示内容1
</div></li>
<li>
<div class="txt">
<i>人之初,性本善</i>
</div></li>
<li>
<div class="txt">
显示内容2<br />显示<br />...<br />显示内容2!
</div></li>
</ul>
</body>
</html>

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
JavaScript/jQuery 表单美化插件小结
Feb 14 Javascript
js获取系统的根路径实现介绍
Sep 08 Javascript
jqueyr判断checkbox组的选中(示例代码)
Nov 08 Javascript
四种参数传递的形式——URL,超链接,js,form表单
Jul 24 Javascript
Bootstrap3制作图片轮播效果
May 12 Javascript
详解如何在Angular中快速定位DOM元素
May 17 Javascript
js+html5实现侧滑页面效果
Jul 15 Javascript
浅谈Angularjs中不同类型的双向数据绑定
Jul 16 Javascript
JavaScript静态作用域和动态作用域实例详解
Jun 17 Javascript
vuex存储token示例
Nov 11 Javascript
Vue基础配置讲解
Nov 29 Javascript
JavaScript代码简化技巧实例解析
Sep 09 Javascript
jQuery结合CSS制作漂亮的select下拉菜单
May 03 #Javascript
jQuery实现的向下图文信息滚动效果
May 03 #Javascript
JQuery插件Quicksand实现超炫的动画洗牌效果
May 03 #Javascript
JQuery页面地址处理插件jqURL详解
May 03 #Javascript
jQuery的animate函数实现图文切换动画效果
May 03 #Javascript
php+ajax+jquery实现点击加载更多内容
May 03 #Javascript
jquery插件hiAlert实现网页对话框美化
May 03 #Javascript
You might like
《忧国的莫里亚蒂》先导宣传图与STAFF公开
2020/03/04 日漫
数组与类使用PHP的可变变量名需要的注意的问题
2013/06/20 PHP
PHP生成器简单实例
2015/05/13 PHP
iis 7下安装laravel 5.4环境的方法教程
2017/06/14 PHP
实例分析基于PHP微信网页获取用户信息
2017/11/24 PHP
PHP获取HTTP body内容的方法
2018/12/31 PHP
Javascript中的相等与不等运算
2010/04/25 Javascript
Android中资源文件(非代码部分)的使用概览
2012/12/18 Javascript
js为数字添加逗号并格式化数字的代码
2013/08/23 Javascript
jQuery插件 selectToSelect使用方法
2013/10/02 Javascript
Jquery实现的tab效果可以指定默认显示第几页
2013/10/16 Javascript
原生JavaScript实现连连看游戏(附源码)
2013/11/05 Javascript
实现51Map地图接口(示例代码)
2013/11/22 Javascript
react.js 翻页插件实例代码
2017/01/19 Javascript
微信小程序实现获取自己所处位置的经纬度坐标功能示例
2017/11/30 Javascript
100行代码实现一个vue分页组功能
2018/11/06 Javascript
5分钟教你用nodeJS手写一个mock数据服务器的方法
2019/09/10 NodeJs
Vue自动构建发布脚本的方法示例
2020/07/24 Javascript
python基于windows平台锁定键盘输入的方法
2015/03/05 Python
Python中自定义函数的教程
2015/04/27 Python
pytorch查看通道数 维数 尺寸大小方式
2020/05/26 Python
倩碧美国官网:Clinique美国
2016/07/20 全球购物
Lookfantastic葡萄牙官方网站:欧洲第一大化妆品零售商
2018/03/17 全球购物
雷曼兄弟的五金店:Lehman’s Hardware Store
2019/04/10 全球购物
斯福泰克软件测试面试题
2015/02/16 面试题
大学生年度自我鉴定
2013/10/31 职场文书
护士辞职信范文
2014/01/19 职场文书
两只小狮子教学反思
2014/02/05 职场文书
秸秆管理实施方案
2014/03/15 职场文书
建房协议书
2014/04/11 职场文书
小学生环保倡议书
2014/05/15 职场文书
国际贸易本科毕业生求职信
2014/09/26 职场文书
我们的节日重阳节活动总结
2015/03/24 职场文书
详解Nginx 被动检查服务器的存活状态
2021/10/16 Servers
PHP获取学生成绩的方法
2021/11/17 PHP
MySQL数据库中的锁、解锁以及删除事务
2022/05/06 MySQL