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 相关文章推荐
JS解密入门 最终变量劫持
Jun 25 Javascript
Jquery为a标签的href赋值实现代码
May 03 Javascript
jquery ready函数、css函数及text()使用示例
Sep 27 Javascript
JavaScript事件委托用法分析
Jan 24 Javascript
JavaScript学习笔记之数组去重
Mar 23 Javascript
Ajax+FormData+javascript实现无刷新表单信息提交
Oct 24 Javascript
解析Vue2.0双向绑定实现原理
Feb 23 Javascript
ES6新特性七:数组的扩充详解
Apr 21 Javascript
微信小程序 页面跳转传值实现代码
Jul 27 Javascript
细说webpack源码之compile流程-rules参数处理技巧(1)
Dec 26 Javascript
Vue使用vux-ui自定义表单验证遇到的问题及解决方法
May 10 Javascript
浅入深出Vue之自动化路由
Aug 06 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
浅谈Laravel中的一个后期静态绑定
2017/08/11 PHP
浅谈关于PHP解决图片无损压缩的问题
2017/09/01 PHP
JS 分号引起的一段调试问题
2009/06/18 Javascript
jqGrid随窗口大小变化自适应大小的示例代码
2013/12/28 Javascript
使用GruntJS构建Web程序之安装篇
2014/06/04 Javascript
JavaScript定时显示广告代码分享
2015/03/02 Javascript
检测一个函数是否是JavaScript原生函数的小技巧
2015/03/13 Javascript
jQuery实现鼠标滑过点击事件音效试听
2015/08/31 Javascript
node.js缺少mysql模块运行报错的解决方法
2016/11/13 Javascript
JavaScript函数节流和函数防抖之间的区别
2017/02/15 Javascript
vue2中filter()的实现代码
2017/07/09 Javascript
使用vue构建移动应用实战代码
2017/08/02 Javascript
AngularJs点击状态值改变背景色的实例
2017/12/18 Javascript
Vue路由模块化配置的完整步骤
2019/08/14 Javascript
Node.js 深度调试方法解析
2020/07/28 Javascript
Vue使用CDN引用项目组件,减少项目体积的步骤
2020/10/30 Javascript
vue 实现基础组件的自动化全局注册
2020/12/25 Vue.js
python访问系统环境变量的方法
2015/04/29 Python
Python socket网络编程TCP/IP服务器与客户端通信
2017/01/05 Python
linux环境下python中MySQLdb模块的安装方法
2017/06/16 Python
Python元组常见操作示例
2019/02/19 Python
python实现矩阵打印
2019/03/02 Python
python求最大值,不使用内置函数的实现方法
2019/07/09 Python
python 3.8.3 安装配置图文教程
2020/05/21 Python
Django DRF认证组件流程实现原理详解
2020/08/17 Python
python包的导入方式总结
2021/03/02 Python
使用CSS3制作饼状旋转载入效果的实例
2015/06/23 HTML / CSS
将SVG图引入到HTML页面的实现
2019/09/20 HTML / CSS
Mansur Gavriel官网:纽约市的一个设计品牌
2019/05/02 全球购物
Timberland澳大利亚官网:全球领先的户外品牌
2019/12/10 全球购物
后勤岗位职责
2013/11/26 职场文书
银行员工辞职信范文
2014/01/20 职场文书
培训协议书范本
2014/04/22 职场文书
第一军规观后感
2015/06/12 职场文书
利用For循环遍历Python字典的三种方法实例
2022/03/25 Python
使用Ajax实现进度条的绘制
2022/04/07 Javascript