刚写完,欢迎大家帮忙测试 完整的测试代码:
高级目录,文件名排序
#page{}
高级目录,文件名排序
主要实现了目录中的数字按大小排序
排序结果:
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]主要的排序功能源码如下(v1): 复制代码 代码如下: var fileSort=function(arr){ arr.sort(); var res=[],temp=[],i=0,j=0,k,reg,sc=true,cur=arr[0]; while(cur.charCodeAt(0)<48){//数字之前的标点等开头的 res[i]=cur; if(i===arr.length-1)return res; cur=arr[++i]; } while(cur.charCodeAt(0)<58){//以数字开头的 temp[j++]=cur; if(i===arr.length-1)break; cur=arr[++i]; } temp.sort(function(a,b){//排序以数字开头的 return parseInt(a,10)-parseInt(b,10); }); res=res.concat(temp); temp=[];j=0; for(;i<arr.length;i++){ cur=arr[i]; if((k=cur.search(/d+/))===-1 || i===arr.length-1){//最后一个文件时直接添加 res[i]=cur; }else { reg=new RegExp("^"+cur.substr(0,k)+"\d+"); while(cur.search(reg)!==-1){ temp[j++]=cur; if(i===arr.length-1)break; cur=arr[++i]; } if(temp.length>0){ temp.sort(function(a,b){ return parseInt(a.substr(k),10)-parseInt(b.substr(k),10); }); res=res.concat(temp); temp=[];j=0; i-=1;//减1,再执行查找使while结束的str } } } return res; } 后来想想,上面的版本中,前面 两个while完全是多余 的,而且去掉之后 ,直接就支持了特殊字符后面中包含数字的排序 v2(注意RegExp尚未escape): 复制代码 代码如下: var fileSort=function(arr){ arr.sort(); var res=[],temp=[],i=0,j=0,k,reg,cur; for(;i<arr.length;i++){ cur=arr[i]; if((k=cur.search(/d+/))===-1 || i===arr.length-1){//最后一个文件时直接添加 res[i]=cur; }else { reg=new RegExp("^"+cur.substr(0,k)+"\d+"); while(cur.search(reg)!==-1){ temp[j++]=cur; if(i===arr.length-1)break; cur=arr[++i]; } if(temp.length>0){ temp.sort(function(a,b){ return parseInt(a.substr(k),10)-parseInt(b.substr(k),10); }); res=res.concat(temp); temp=[];j=0; i-=1;//减1,再执行查找使while结束的str } } } return res; } 另外,最近用jq的发现: 1 :hidden 这个选择会选择所有不可见元素,如果是clone()的元素,还没添加到dom时,都是属于不可见 2 .serialize() 使用这个方法时,需要为form内的表单元素指定name,否则这个方法返回空字符串 3 jstree插件不能与早版本的validate插件同时使用,因为早版本的validate重新了jq的delegate方法,更新版本就好了 4 ui中DatePicker插件不能与有.hasDatepicker的文本框绑定 ,需要先去掉此类名,才行 5 closest,live(delegate)真是好用的方法
推荐阅读
jquery 插件开发备注
今天发现其实JQ自己早就有对这个临时数据的存储方法: $("dom").data(“mydata”,"this is data");还有就是插件开发的时候我们经常要给插件添加方法,其实就用JS内部添加方法的方法即可 this.myfn=function(){} 下面>>>详细阅读
本文标题:javascript高级的文件目录排序代码
地址:http://www.17bianji.com/kaifa2/JS/25799.html
1/2 1