sort - javascript 手動(dòng)指定對(duì)象陣列的順序
問(wèn)題描述
我有一個(gè)對(duì)象陣列,我希望他照我自己指定好的順序做排列,如下,依照我指定好的name順序做排列,純?cè)鷍avascript我會(huì)使用以下的方式做,請(qǐng)問(wèn)有沒(méi)有l(wèi)odash或其他第三方的知名套件,可以達(dá)到如下的效果,或者說(shuō)有其他更有效率 簡(jiǎn)單的寫(xiě)法?
var arr = [ {name:’小麥’,phone:’112233’ }, {name:’綠綠’,phone:’4445566’ }, {name:’增增’,phone:’321321’ }, {name:’弱弱’,phone:’123123’ }];//希望達(dá)到的順序 (我已知所有元素)var order = { ’增增’:0, ’弱弱’:1, ’綠綠’:2, ’小麥’:3};var newOrderedArr = [];arr.forEach((element)=>{ newOrderedArr[order[element.name]] = element;});console.log(newOrderedArr);
console的結(jié)果如下
[ { name: ’增增’, phone: ’321321’ }, { name: ’弱弱’, phone: ’123123’ }, { name: ’綠綠’, phone: ’4445566’ }, { name: ’小麥’, phone: ’112233’ } ]
問(wèn)題解答
回答1:如果 orders 里面是按 0 ~ n 的連續(xù)值,那你的方法已經(jīng)非常非常快了,其它庫(kù)方法達(dá)不到這個(gè)速度(因?yàn)樗鼈儠?huì)考慮不連續(xù)的情況)
如果不連續(xù),可以用 sort
newOrderedArr = arr.sort((a, b) => order[a.name] - order[b.name]);
或者也可以用你的辦法,再加個(gè)過(guò)濾
newOrderedArr = newOrderedArr.filter(n => n);
補(bǔ)充:對(duì)非連續(xù)序號(hào)的情況,加不加排序的比較如圖
這個(gè)思路覺(jué)得已經(jīng)很快了。從易用的角度看 order 的 index 可以生成,這樣每次輸入名字的數(shù)組即可。
但如果有重名則不行。得為每個(gè)名字維護(hù)個(gè)數(shù)組記錄,最后再 concat 起來(lái)
相關(guān)文章:
1. 查詢(xún)mysql數(shù)據(jù)庫(kù)中指定表指定日期的數(shù)據(jù)?有詳細(xì)2. mysql - 怎么生成這個(gè)sql表?3. mysql儲(chǔ)存json錯(cuò)誤4. php - 公眾號(hào)文章底部的小程序二維碼如何統(tǒng)計(jì)?5. mysql - 表名稱(chēng)前綴到底有啥用?6. mysql - 數(shù)據(jù)庫(kù)表中,兩個(gè)表互為外鍵參考如何解決7. Navicat for mysql 中以json格式儲(chǔ)存的數(shù)據(jù)存在大量反斜杠,如何去除?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語(yǔ)法實(shí)現(xiàn)存在即更新應(yīng)該使用哪個(gè)標(biāo)簽?9. mysql - 數(shù)據(jù)庫(kù)建字段,默認(rèn)值空和empty string有什么區(qū)別 11010. sql語(yǔ)句 - 如何在mysql中批量添加用戶(hù)?
