如何让 localeCompare 的行为与 .sort() 类似,以便所有大写字母排在前面?

Sno*_*now 8 javascript sorting

我有一个要排序的字符数组:

const arr = ['z', 'a', 'Z', 'A'];
Run Code Online (Sandbox Code Playgroud)

我希望排序顺序为:按字母顺序排列大写字符,然后按字母顺序排列小写字符:

['A', 'Z', 'a', 'z']
Run Code Online (Sandbox Code Playgroud)

不使用任何参数即可轻松完成此操作.sort()

const arr = ['z', 'a', 'Z', 'A'];
Run Code Online (Sandbox Code Playgroud)

但如何才能localeCompare确定每个字符的相对位置相同呢?caseFirst选项看起来很有希望:

无论大写还是小写都应该先排序。可能的值为“upper”、“lower”或“false”(使用区域设置的默认值);默认值为“假”。该选项可以通过选项属性或通过 Unicode 扩展键来设置;如果两者都提供,则 options 属性优先。

但它似乎并没有达到我想要的效果。我尝试过很多变体:

我希望它的执行类似于.sort()(至少对于字母字符),它比较每个字符的代码点:

const arr = ['z', 'a', 'Z', 'A'];
arr.sort();
console.log(arr);
Run Code Online (Sandbox Code Playgroud)

当然,我知道我可以简单地避免localeCompare并使用.sort()而不使用回调,或者使用charCodeAt上面的方法:

// Desired result: ['A', 'Z', 'a', 'z']

const arr = ['z', 'a', 'Z', 'A'];
arr.sort((a, b) => a.localeCompare(b));
console.log(arr);
arr.sort((a, b) => a.localeCompare(b, undefined, { caseFirst: 'upper' }));
console.log(arr);
arr.sort((a, b) => a.localeCompare(b, undefined, { sensitivity: 'case', caseFirst: 'upper' }));
console.log(arr);
arr.sort((a, b) => a.localeCompare(b, 'en', { caseFirst: 'upper' }));
console.log(arr);
arr.sort((a, b) => a.localeCompare(b, 'kf', { caseFirst: 'upper' }));
console.log(arr);
Run Code Online (Sandbox Code Playgroud)

但我该如何使用localeCompare呢?

小智 -2

能够使用它按字典顺序对数组进行排序。

const lexicalCompare = (a, b) =>
  a < b ? -1 : (a > b ? 1 : 0);

const arr = ['z', 'a', 'Z', 'A'];

console.log(arr.sort(lexicalCompare));
Run Code Online (Sandbox Code Playgroud)

  • 这与没有分拣员OP说他们不想要的一样。他们想使用“localeCompare”(因为我不知道什么原因) (2认同)