Я просто хочу отсортировать слова из массива в алфавитном порядке по 1-й букве, а затем по 2-й букве в соответствии с моим заданным шаблоном, который соответствует 1-й букве

♦ узор: e,b,c,d,i,f,g,h,o,j,k,l,m,n,u,p,q,r,s,t,a,v,w,x,y, г

Я хочу отсортировать слова из arr в алфавитном порядке по 1-й букве, а затем по 2-й букве аналогичного слова, совпадающего с 1-й буквой, в соответствии с моим заданным шаблоном.

['aobcdh', 'aibcdh', 'aabcdh', 'aacbdh', 'cfghjd', 'cighjd']

♦ вывод должен быть:

['aibcdh', 'aobcdh', 'aabcdh', 'aacbdh', 'cighjd', 'cfghjd' ]

♦ или:aibcdh aobcdh aabcdh aacbdh cighjd cfghjd

My Code here:

    let pattern = ['e', 'b', 'c', 'd', 'i', 'f', 'g', 'h', 'o', 'j', 'k', 'l', 'm', 'n', 'u', 'p', 'q', 'r', 's', 't', 'a', 'v', 'w', 'x', 'y', 'z']
let arr = ['aobcdh', 'aibcdh', 'aabcdh', 'aacbdh', 'cfghjd', 'cighjd']
let arrSorted = arr.sort() //Natural sorting
console.info(arrSorted)

// output in array
const newArr = arrSorted.sort((a, b) => pattern.indexOf(a[1]) - pattern.indexOf(b[1]))
console.info(newArr) //Sorted by its 2nd character with given pattern

// single output without array
for (let i = 0; i < pattern.length; i++) {
    for (let j = 0; j < arrSorted.length; j++) {
        if (pattern[i] === arrSorted[j][1]) {
            console.info(arrSorted[j]) //Sorted by its 2nd character with given pattern
        }
    }
}

🤔 А знаете ли вы, что...
JavaScript может выполняться как на стороне клиента (в браузере), так и на стороне сервера (с использованием Node.js).


11
1

Ответ:

Решено

Вы можете отсортировать первое по строке, а второе по пользовательскому значению.

const
    pattern = 'ebcdifghojklmnupqrstavwxyz',
    array = ['aobcdh', 'aibcdh', 'aabcdh', 'aacbdh', 'cfghjd', 'cighjd'],
    order = Object.fromEntries(Array.from(pattern, (l, i) => [l, i + 1]));

array.sort((a, b) =>
    a[0].localeCompare(b[0]) ||
    order[a[1]] - order[b[1]]
);

console.info(array);