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的IE和Firefox兼容性汇编(zz)
Feb 02 Javascript
Node.js实现简单聊天服务器
Jun 20 Javascript
js实现屏幕自适应局部代码分享
Jan 30 Javascript
JavaScript使用位运算符判断奇数和偶数的方法
Jun 01 Javascript
JS基于Mootools实现的个性菜单效果代码
Oct 21 Javascript
js基于cookie记录来宾姓名的方法
Jul 19 Javascript
微信小程序购物商城系统开发系列-工具篇的介绍
Nov 21 Javascript
AngularJS封装指令方法详解
Dec 12 Javascript
简单实现js鼠标跟随效果
Aug 02 Javascript
浅谈mvvm-simple双向绑定简单实现
Apr 18 Javascript
JQuery Ajax跨域调用和非跨域调用问题实例分析
Apr 16 jQuery
Nautil 中使用双向数据绑定的实现
Oct 02 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
一个PHP日历程序
2006/12/06 PHP
php获取通过http协议post提交过来xml数据及解析xml
2012/12/16 PHP
php中Y2K38的漏洞解决方法实例分析
2014/09/22 PHP
PHP中的替代语法介绍
2015/01/09 PHP
php获取网页上所有链接的方法
2015/04/03 PHP
PHP中把对象数组转换成普通数组的方法
2015/07/10 PHP
javascript对数组的常用操作代码 数组方法总汇
2011/01/27 Javascript
jQuery弹出(alert)select选择的值
2013/04/21 Javascript
JQuery中DOM加载与事件执行实例分析
2015/06/13 Javascript
BetterScroll 在移动端滚动场景的应用
2017/09/18 Javascript
react同构实践之实现自己的同构模板
2019/03/13 Javascript
微信小程序获取用户信息的两种方法wx.getUserInfo与open-data实例分析
2019/05/03 Javascript
详解Vue demo实现商品列表的展示
2019/05/07 Javascript
通过javascript实现段落的收缩与展开
2019/06/26 Javascript
layui-tree实现Ajax异步请求后动态添加节点的方法
2019/09/23 Javascript
JS中FileReader类实现文件上传及时预览功能
2020/03/27 Javascript
微信小程序swiper组件实现抖音翻页切换视频功能的实例代码
2020/06/24 Javascript
[00:15]天涯墨客终极技能展示
2018/08/25 DOTA
Python实现简单查找最长子串功能示例
2019/02/26 Python
python 队列基本定义与使用方法【初始化、赋值、判断等】
2019/10/24 Python
pytorch中的上采样以及各种反操作,求逆操作详解
2020/01/03 Python
Python 如何实现数据库表结构同步
2020/09/29 Python
python math模块的基本使用教程
2021/01/16 Python
45个非常奇妙的CSS3 特性应用示例
2012/01/01 HTML / CSS
Abe’s of Maine:自1979以来销售相机和电子产品
2016/11/21 全球购物
美国销售第一的智能手机和平板电脑保护壳:OtterBox
2017/12/21 全球购物
Europcar西班牙:全球汽车租赁领域的领导者
2018/09/17 全球购物
澳大利亚便宜隐形眼镜购买网站:QUICKLENS Australia
2018/10/06 全球购物
世界汽车零件:World Car Parts
2019/09/04 全球购物
俄罗斯药房连锁店:ASNA
2020/06/20 全球购物
与C++相比,Java中的数组有什么不同
2014/03/25 面试题
职业培训师职业生涯规划
2014/02/18 职场文书
2014年护理工作总结范文
2014/11/14 职场文书
防卫过当辩护词
2015/05/21 职场文书
电工生产实习心得体会
2016/01/22 职场文书
sqlserver2017共享功能目录路径不可改的解决方法
2021/04/16 SQL Server