第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

按特定順序?qū)?JS 數(shù)值數(shù)組進行排序

按特定順序?qū)?JS 數(shù)值數(shù)組進行排序

慕妹3242003 2023-02-24 16:31:18
我有一個數(shù)組[1, 85, -1, -1, 25, 0]我需要這樣排序: [0, 1, 25, 85, -1, -1]嘗試使用 sort() 方法但沒有運氣,因為它不是 ASC 順序......邏輯:值代表距離上次訂單的天數(shù)。-1代表沒有順序。要求按最近訂購的順序訂購。
查看完整描述

3 回答

?
慕碼人8056858

TA貢獻1803條經(jīng)驗 獲得超6個贊

在sort回調(diào)中,您收到兩個參數(shù)(我通常稱它們a為 和b)。a如果應(yīng)該在 之前返回一個負數(shù)b,如果無關(guān)緊要則返回 0(出于排序目的它們是相同的),如果a應(yīng)該在 之后返回一個正數(shù)b。


在您的情況下,由于 -1 最后出現(xiàn)(您說過沒有其他負數(shù)),您只需要對其進行特殊處理:


array.sort((a, b) => {

    if (a === -1) { // < 0 would also work, since there aren't any others

        return 1;

    }

    if (b === -1) { // "

        return -1;

    }

    return a- b;

});

現(xiàn)場示例:


顯示代碼片段


那可以更簡潔,當然,我寫成上面主要是為了最大程度的清楚。但是例如:


array.sort((a, b) => a === -1 ? 1 : b === -1 ? -1 : a - b);

就我個人而言,我更喜歡稍微冗長一點。但... :-)


查看完整回答
反對 回復 2023-02-24
?
慕村225694

TA貢獻1880條經(jīng)驗 獲得超4個贊

您可以檢查是否小于零并將其余的升序排序。


var array = [1, 85, -1, -1, 25, 0];


array.sort((a, b) => (a < 0) - (b < 0) || a - b);


console.log(array);


查看完整回答
反對 回復 2023-02-24
?
瀟湘沐

TA貢獻1816條經(jīng)驗 獲得超6個贊

您可以sort()像往常一樣,然后使用and明確地將-1s 移到末尾。splice()push()


let arr = [1, 85, -1, -1, 25, 0];

arr.sort((a, b) => a - b);

let idx = arr.findIndex(a => a != -1);

arr.push(...arr.splice(0, idx));

console.log(arr);


查看完整回答
反對 回復 2023-02-24
  • 3 回答
  • 0 關(guān)注
  • 146 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號