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代码)
Apr 11 Javascript
『JavaScript』限制Input只能输入数字实现思路及代码
Apr 22 Javascript
jQuery学习笔记之2个小技巧
Jan 19 Javascript
MVVM模式中ViewModel和View、Model有什么区别?
Jun 19 Javascript
tuzhu_req.js 实现仿百度图片首页效果
Aug 11 Javascript
bootstrap 下拉多选框进行多选传值问题代码分析
Feb 14 Javascript
js仿淘宝商品放大预览功能
Mar 15 Javascript
解决Vue页面固定滚动位置的处理办法
Jul 13 Javascript
微信小程序开发之IOS和Android兼容的问题
Sep 26 Javascript
webpack下实现动态引入文件方法
Feb 22 Javascript
Node.js设置定时任务之node-schedule模块的使用详解
Apr 28 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
PHP面向对象编程快速入门
2006/10/09 PHP
如何在PHP中使用Oracle数据库(3)
2006/10/09 PHP
php+dojo 的数据库保存拖动布局的一个方法dojo 这里下载
2007/03/07 PHP
php缓存技术详细总结
2013/08/07 PHP
js限制文本框只能输入数字(正则表达式)
2012/07/15 Javascript
基于javascript实现的搜索时自动提示功能
2014/12/26 Javascript
JS添加或修改控件的样式(Class)实现方法
2016/10/15 Javascript
vue踩坑记录之数组定义和赋值问题
2019/03/20 Javascript
vue2 v-model/v-text 中使用过滤器的方法示例
2019/05/09 Javascript
详解如何修改 node_modules 里的文件
2020/05/22 Javascript
一文秒懂JavaScript构造函数、实例、原型对象以及原型链
2020/08/25 Javascript
详解vue中使用transition和animation的实例代码
2020/12/12 Vue.js
vue-router路由懒加载及实现的3种方式
2021/02/28 Vue.js
跟老齐学Python之有容乃大的list(1)
2014/09/14 Python
python 拷贝特定后缀名文件,并保留原始目录结构的实例
2018/04/27 Python
手机使用python操作图片文件(pydroid3)过程详解
2019/09/25 Python
TensorFlow tf.nn.max_pool实现池化操作方式
2020/01/04 Python
python如何变换环境
2020/07/21 Python
喜诗官方在线巧克力店:See’s Candies
2017/01/01 全球购物
Liu Jo西班牙官网:意大利服装品牌
2019/09/11 全球购物
常用UNIX 命令(Linux的常用命令)
2015/12/26 面试题
XMLHttpRequest对象在IE和Firefox中创建方式有没有不同
2016/03/23 面试题
中软国际Java程序员笔试题
2014/07/19 面试题
酒店服务实习自我鉴定
2013/09/22 职场文书
项目考察欢迎辞
2014/01/17 职场文书
毕业生就业协议书
2014/04/11 职场文书
计算机科学与技术专业求职信
2014/09/03 职场文书
离婚协议书格式
2014/11/21 职场文书
小学三八妇女节活动总结
2015/02/06 职场文书
办公室年度工作总结2015
2015/05/21 职场文书
法定代表人资格证明书
2015/06/18 职场文书
2015年秋季小学开学标语
2015/07/16 职场文书
css 中多种边框的实现小窍门
2021/04/07 HTML / CSS
python 实现图与图之间的间距调整subplots_adjust
2021/05/21 Python
Python turtle实现贪吃蛇游戏
2021/06/18 Python
MySQL中的 inner join 和 left join的区别解析(小结果集驱动大结果集)
2023/05/08 MySQL