首页 > web前端 > js教程 > 正文

javascript小组件 原生table排序表格脚本(兼容ie firefox opera chrome)_javascript技巧

php中文网
发布: 2016-05-16 17:51:34
原创
1299人浏览过

首先创建html页面为sort.html ,并把下面的内容复制进去

Phenaki
Phenaki

phenaki是一种从文本生成视频的模型

Phenaki 93
查看详情 Phenaki
复制代码 代码如下:





无标题文档

























ID|- name|-
1 开心
3 开饭
5 开放






















ID|- name|-
1 开心
3 开饭
5 开放





新建脚本页 sort.js
复制代码 代码如下:

/*
表格排序功能
事件:2012 7 24
DOM 节点
如果表格需要排序 在表格属性中添加 sort="true"
并且 id是唯一并且是必须的
此js文件直接引入即可
因为制作的仓储 没有注释





















ID|- name|-
1 开心
3 开饭
5 开放

*/
var Core = (function(window){
return {
init: function(){
Core.getTableById();
Core.setHeadClick();
},
I: function(id){
return document.getElementById(id);
},
N: function(name){
return document.getElementsByTagName(name);
},
config: {
arr:[]
},
getTableById: function(){
var table_arr=Core.N("table");
for(var i = 0; i if(table_arr[i].getAttribute("sort")){
Core.config.arr.push(table_arr[i].getAttribute("id"));
}
}
//alert(Core.config.arr)
},
setHeadClick: function(){
var arr = Core.config.arr;
if(!arr.length) return false;
for(var j = 0 ; jvar thead = Core.I(arr[j]).getElementsByTagName("thead")[0].getElementsByTagName("td");
for(var i = 0; iif(thead[i].attachEvent){
thead[i].attachEvent("onclick",Core.sortList)
}else{
thead[i].addEventListener("click",Core.sortList,false)
}
//if(i==0){
// thead[i].click();
// }
}
}
},
sortList: function(e){
var index=0,arr=[],sort="asc",table=null;
if(e.srcElement){
index=e.srcElement.cellIndex;
sort=e.srcElement.getAttribute("sort");
e.srcElement.className=sort == "asc" ? "desc" : "asc";
e.srcElement.setAttribute("sort", sort == "asc" ? "desc" : "asc");
table = Core.getTableId(e.srcElement)
}else{
index=e.currentTarget.cellIndex;
sort=e.currentTarget.getAttribute("sort");
e.currentTarget.className=sort == "asc" ? "desc" : "asc";
e.currentTarget.setAttribute("sort", sort == "asc" ? "desc" : "asc");
table = Core.getTableId(e.currentTarget)
}
Core.getList(table,index,arr);
Core.updateList(table,sort,arr);
},
getTableId: function(p){
for(var i=0,n=p;n=n.parentNode;i++){
if(i>100) break;
if(n.nodeName=="TABLE"){
//alert(n.nodeName/*n.getAttribute("id")*/)
return n;
}
}
},
getList: function (table,index,arr){
var table = table.getElementsByTagName("tbody")[0];
for(var i = 0; ivar item = table.rows[i];
for(var j = 0; jvar jtem = item.cells[index];
if(jtem.innerHTML){
//alert(jtem.innerHTML)
arr[i]=jtem.innerHTML;
}
break;
}
}
},
updateList: function (table,sort,arr){
var table = table.getElementsByTagName("tbody")[0];
for(var i = 0; ifor(var j = i+1;jif(sort=="asc"){
if(arr[i] > arr[j]){
var rwos=table.rows[i].cloneNode(true);
table.replaceChild(table.rows[j],table.rows[i]);
if(j+1==arr.length){
//table.insertBefore(rwos,null);
table.appendChild(rwos)
}else{
table.insertBefore(rwos,table.rows[j]);
}
var tim= arr[i];
arr.splice(i,1,arr[j]);
arr.splice(j,1,tim);
}
}else{
if(arr[i] var rwos=table.rows[i].cloneNode(true);
table.replaceChild(table.rows[j],table.rows[i]);
if(j+1==arr.length){
//table.insertBefore(rwos,null);
table.appendChild(rwos)
}else{
table.insertBefore(rwos,table.rows[j]);
}
var tim= arr[i];
arr.splice(i,1,arr[j]);
arr.splice(j,1,tim);
}
}
}
}
}
};
})(window);
window.onload=Core.init;
java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号