/**
*
* @param array 需要排序的数组。['a','哇']
* @param key 需要返回的数组key
*/
function sort(array, key) {
if(!key.toLocaleLowerCase().match(/[a-z]/ || !Array.isArray(array) || array.length === 0)) {
throw Error('传的参数有问题')
}
function compare(a, b) {
return a.localeCompare(b, 'zh-CN')
}
const letters = 'abcdefghjklmnopqrstwxyz'.split(''),
zh = '阿八嚓哒妸发旮哈讥咔垃痳拏噢妑七呥扨它穵夕丫帀'.split(''),
index = key && letters.indexOf(key.toLocaleLowerCase()),
result = []
array.forEach(value => {
if(value[0].toLocaleLowerCase() === key.toLocaleLowerCase() || compare(zh[index],value[0]) <= 0 && (!zh[index + 1] || compare(value[0], zh[index+1]) < 0)) {
result.push(value)
}
})
result.sort((a, b) => compare(a, b))
return result
}
console.log(sort(['aaa','bb','a', '哇','吧','这','啊','阿','锕','aaa','abc','bc'], 'a'))
//["阿", "锕", "啊", "a", "aaa", "aaa", "abc"]
此函数的关键就是localeCompare函数。在stackoverflow提问中,有人提到要用到a.localeCompare(b,'zh-CN'),其中"zh-CN",特别重要。这个参数使localeCompare函数使用中文拼音规则进行比较大小。
还有zh数组,这是我在网上另外一篇博客中取得,这个数组的作用就是取到拼音对应的最小文字。阿就是拼音a对应的最小中文字符(使用localeCompare进行比较时)。但我无法保证这个数组中的每一个字符都是对应拼音最小的字符。在网上的博客中没有一个人能说明这个数组中的数据为什么正确。我本人也没有找到相关资料,所以只能暂且使用这些数据。