js sort 二維數(shù)組排序的用法小結(jié)
最近在搞js 排序的問題,因?yàn)閿?shù)據(jù)庫排序太耗資源,如果能轉(zhuǎn)移到客戶端去排序,能大大D減少服務(wù)器內(nèi)存消耗??蛻舳说脑?,除了js,就是as了,可惜我as學(xué)得太爛,所以只能選擇js來研究研究了。。。經(jīng)過我的測試,js內(nèi)置方法sort的效率非常高
我們知道在js中默認(rèn)提供了sort函數(shù),但是這個函數(shù)默認(rèn)是按照數(shù)組內(nèi)容的ascii碼升序進(jìn)行排列的,如果我們要對二維數(shù)組排序要如何做呢?在php中是有multi_sort函數(shù)可供調(diào)用的,但是在js中似乎沒有這種函數(shù),但是沒關(guān)系 ,因?yàn)閖s的sort函數(shù)其實(shí)也提供了參數(shù)可以定義比較函數(shù)進(jìn)行二維數(shù)組的排序。
1、按數(shù)值排序
假設(shè)有如下數(shù)組
var arr = [[1, 2, 3], [7, 2, 3], [3, 2, 3]];
這里如果我們要按每個子數(shù)組的第一列來排序要如何做呢,我們可以定義一個比較函數(shù):
arr.sort(function(x, y){
return x[0] – y[0];
});
這里的比較函數(shù)的作用是什么呢?其實(shí)是數(shù)組依次將數(shù)組元素復(fù)制給x,y,比如首先將arr[0]賦給x,arr[1]賦給y,然后用x[0] – y[0],根據(jù)返回的值,如果返回的是大于0的數(shù),那么就把數(shù)組中x放到y(tǒng)的后面,如果返回的是0則不變,小于0則將x放到y(tǒng)的前面,然后第一個排序好之后在進(jìn)行下面兩個的排序,直到整個數(shù)組排序完成。這是默認(rèn)升序的比較函數(shù),如果要降序排列則只需修改比較方式,改為 return y[0] – x[0] 即可,這里我們x[0]表示是按第一列進(jìn)行排序,我們這里也可以按其他列進(jìn)行排序。這里的排序默認(rèn)就會修改arr的數(shù)組結(jié)構(gòu),所以排序完arr就是按第一列升序的數(shù)組了。
2、按字符串排序
按字符串排序的話呢,我們可以利用js提供的localeCompare方法,
localeCompare作用:用本地特定的順序來比較兩個字符串。
localeCompare方法的使用規(guī)則是stringObject.localeCompare(target),如果 stringObject 小于 target,則 localeCompare() 返回小于 0 的數(shù)。如果 stringObject 大于 target,則該方法返回大于 0 的數(shù)。如果兩個字符串相等,或根據(jù)本地排序規(guī)則沒有區(qū)別,該方法返回 0,器比較使用的是本地的規(guī)則,本地規(guī)則意思就是使用操作系統(tǒng)底層對這些本地字符排序的規(guī)則進(jìn)行排序,默認(rèn)情況下比如使用大于號這樣的比較只是純粹比較兩個字符的unicode的數(shù)大小,會與很多語言不符。
比如
var arr = [['中','國'], ['啊','的'], ['哦','的']];
arr.sort(function(x, y){
return x[0].localeCompare(y[0]);
});
結(jié)果就會按第一列中文字的拼音排序,如果含有英文的話,默認(rèn)是將英文放在前面,如果是純英文的話,會按字母順序來,大寫排在小寫的后面,這樣就可以實(shí)現(xiàn)字符串的排序了,包括中文和中英混排。至于要降序排列的話,方法與上面相同,改成return y[0].localeCompare(x[0]); 即可。
這樣排序的問題就實(shí)現(xiàn)了,js二維數(shù)組排序用到的地方還是很多的。希望能幫到些人的忙吧
function tblSort(s){
for(r = 0;r < row_len;r++){
arrs[r]=[]
for(c=0;c<cel_len;c++){
arrs[r][c] ={}//二維數(shù)組里再創(chuàng)建一個對象;
arrs[r][c].html = table.rows[r].cells[c].innerHTML//取表格HTML放進(jìn)一個關(guān)聯(lián)數(shù)組里面,用于排序后顯示在頁面上;
var text = table.rows[r].cells[c].innerText//取得表格的文字內(nèi)容用于下面的判斷;
//檢測可能出現(xiàn)的內(nèi)容如果不是正常的數(shù)據(jù)就變成負(fù)數(shù),排在最后面;
if(text == '-'){
arrs[r][c].text='-1';
}else if(text=='重新檢測'){
arrs[r][c].text='-2';
}else if(text=='無百度快照'||text=='無排名數(shù)據(jù)'){
arrs[r][c].text='-3'
}else if(text == ''){
arrs[r][c].text='-4'
}else{
arrs[r][c].text=table.rows[r].cells[c].innerText//取表格文字內(nèi)容放進(jìn)一個關(guān)聯(lián)數(shù)組里面。用于下面的sort做排序。
}
}
}
//alert(arrs[0][0]['text'])
//reve判斷當(dāng)前是正常排序還是反序;
if(reve){
arrs.sort(function(x,y){
return parseFloat(y[s]['text']) - parseFloat(x[s]['text'])
});
reve=0
}else{
arrs.sort(function(x,y){
return parseFloat(x[s]['text']) - parseFloat(y[s]['text'])//排序
})
reve=1
}
//將排好的html內(nèi)容放入表格里
for(r = 0;r < row_len;r++){
for(c=0;c<cel_len;c++){
table.rows[r].cells[c].innerHTML =arrs[r][c]['html']
}
}
}
//表格排序結(jié)束
- Js數(shù)組排序函數(shù)sort()介紹
- js對數(shù)組中的數(shù)字從小到大排序?qū)崿F(xiàn)代碼
- Javascript數(shù)組的排序 sort()方法和reverse()方法
- JS數(shù)組排序技巧匯總(冒泡、sort、快速、希爾等排序)
- js中數(shù)組(Array)的排序(sort)注意事項(xiàng)說明
- JavaScript中數(shù)組Array.sort()排序方法詳解
- JS實(shí)現(xiàn)根據(jù)數(shù)組對象的某一屬性排序操作示例
- js使用Array.prototype.sort()對數(shù)組對象排序的方法
- JS實(shí)現(xiàn)json對象數(shù)組按對象屬性排序操作示例
- js實(shí)現(xiàn)嵌套數(shù)組重排序
相關(guān)文章
js canvas實(shí)現(xiàn)驗(yàn)證碼并獲取驗(yàn)證碼功能
這篇文章主要為大家詳細(xì)介紹了js canvas實(shí)現(xiàn)驗(yàn)證碼并獲取驗(yàn)證碼功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09基于Arcgis for javascript實(shí)現(xiàn)百度地圖ABCD marker的效果
本篇文章由腳本之家小編給大家分享的基于Arcgis for javascript實(shí)現(xiàn)百度地圖ABCD marker的效果,需要的朋友一起學(xué)習(xí)吧2015-09-09詳解Javascript中document.execCommand()的用法以及指令參數(shù)列表
execCommand方法是執(zhí)行一個對當(dāng)前文檔,當(dāng)前選擇或者給出范圍的命令。在HTML5中,execCommand可以通過JavaScript代碼來調(diào)用,使得開發(fā)者可以在網(wǎng)頁中實(shí)現(xiàn)一些復(fù)雜的文本操作。在HTML編輯器中這個命令用得很多,酷炫的強(qiáng)大功能。2023-07-07JavaScript事件類型中焦點(diǎn)、鼠標(biāo)和滾輪事件詳解
這篇文章主要為大家詳細(xì)介紹了JavaScript事件類型中焦點(diǎn)、鼠標(biāo)和滾輪事件,以及注意事項(xiàng),感興趣的小伙伴們可以參考一下2016-01-01