javascript高級(jí)的文件目錄排序代碼
更新時(shí)間:2010年08月30日 09:59:04 作者:
這幾天在做一個(gè)文件管理的模塊,里面有排序的功能,產(chǎn)品經(jīng)理看了說(shuō)希望能做出更加智能的文件排序功能,就像是win7的名稱排序一樣,主要就是文件名中的數(shù)字會(huì)按大小排序,而不是直接按ascii碼 ,這兩天晚上沒(méi)事,就先寫了這個(gè)排序方法,下個(gè)版本中就可以用上了
剛寫完,歡迎大家?guī)兔y(cè)試
完整的測(cè)試代碼:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
主要的排序功能源碼如下(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){//數(shù)字之前的標(biāo)點(diǎn)等開頭的
res[i]=cur;
if(i===arr.length-1)return res;
cur=arr[++i];
}
while(cur.charCodeAt(0)<58){//以數(shù)字開頭的
temp[j++]=cur;
if(i===arr.length-1)break;
cur=arr[++i];
}
temp.sort(function(a,b){//排序以數(shù)字開頭的
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){//最后一個(gè)文件時(shí)直接添加
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,再執(zhí)行查找使while結(jié)束的str
}
}
}
return res;
}
后來(lái)想想,上面的版本中,前面 兩個(gè)while完全是多余 的,而且去掉之后 ,直接就支持了特殊字符后面中包含數(shù)字的排序
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){//最后一個(gè)文件時(shí)直接添加
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,再執(zhí)行查找使while結(jié)束的str
}
}
}
return res;
}
另外,最近用jq的發(fā)現(xiàn):
1 :hidden 這個(gè)選擇會(huì)選擇所有不可見元素,如果是clone()的元素,還沒(méi)添加到dom時(shí),都是屬于不可見
2 .serialize() 使用這個(gè)方法時(shí),需要為form內(nèi)的表單元素指定name,否則這個(gè)方法返回空字符串
3 jstree插件不能與早版本的validate插件同時(shí)使用,因?yàn)樵绨姹镜膙alidate重新了jq的delegate方法,更新版本就好了
4 ui中DatePicker插件不能與有.hasDatepicker的文本框綁定 ,需要先去掉此類名,才行
5 closest,live(delegate)真是好用的方法
完整的測(cè)試代碼:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
主要的排序功能源碼如下(v1):
復(fù)制代碼 代碼如下:
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){//數(shù)字之前的標(biāo)點(diǎn)等開頭的
res[i]=cur;
if(i===arr.length-1)return res;
cur=arr[++i];
}
while(cur.charCodeAt(0)<58){//以數(shù)字開頭的
temp[j++]=cur;
if(i===arr.length-1)break;
cur=arr[++i];
}
temp.sort(function(a,b){//排序以數(shù)字開頭的
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){//最后一個(gè)文件時(shí)直接添加
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,再執(zhí)行查找使while結(jié)束的str
}
}
}
return res;
}
后來(lái)想想,上面的版本中,前面 兩個(gè)while完全是多余 的,而且去掉之后 ,直接就支持了特殊字符后面中包含數(shù)字的排序
v2(注意RegExp尚未escape):
復(fù)制代碼 代碼如下:
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){//最后一個(gè)文件時(shí)直接添加
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,再執(zhí)行查找使while結(jié)束的str
}
}
}
return res;
}
另外,最近用jq的發(fā)現(xiàn):
1 :hidden 這個(gè)選擇會(huì)選擇所有不可見元素,如果是clone()的元素,還沒(méi)添加到dom時(shí),都是屬于不可見
2 .serialize() 使用這個(gè)方法時(shí),需要為form內(nèi)的表單元素指定name,否則這個(gè)方法返回空字符串
3 jstree插件不能與早版本的validate插件同時(shí)使用,因?yàn)樵绨姹镜膙alidate重新了jq的delegate方法,更新版本就好了
4 ui中DatePicker插件不能與有.hasDatepicker的文本框綁定 ,需要先去掉此類名,才行
5 closest,live(delegate)真是好用的方法
您可能感興趣的文章:
相關(guān)文章
javascript實(shí)現(xiàn) 百度翻譯 可折疊的分享按鈕列表
這篇文章主要介紹了javascript實(shí)現(xiàn) 百度翻譯 可折疊的分享按鈕列表的方法,需要的朋友可以參考下2015-03-03JavaScript實(shí)現(xiàn)日期格式化的方法匯總
日期是許多JavaScript應(yīng)用程序的基本組成部分,無(wú)論是在網(wǎng)頁(yè)上顯示當(dāng)前日期還是處理用戶輸入以安排事件,本文將探討在?JavaScript?中格式化日期的各種技術(shù),希望對(duì)大家有所幫助2023-06-06javascript實(shí)現(xiàn)的樣式表(CSS) 格式整理與壓縮
javascript實(shí)現(xiàn)的樣式表(CSS) 格式整理與壓縮,可以分為多行與單行,非常不錯(cuò)。2010-05-05tween.js緩動(dòng)補(bǔ)間動(dòng)畫算法示例
本篇文章主要介紹了tween.js緩動(dòng)補(bǔ)間動(dòng)畫示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02JavaScript位移運(yùn)算符(無(wú)符號(hào)) >>> 三個(gè)大于號(hào) 的使用方法詳解
這篇文章主要介紹了JavaScript位移運(yùn)算符(無(wú)符號(hào)) >>> 三個(gè)大于號(hào) 的使用方法詳解的相關(guān)資料,需要的朋友可以參考下2016-03-03