自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+

lindsyt

每天进步一点点——everyday grows better!

  • 博客(0)
  • 资源 (1)
  • 收藏
  • 关注

空空如也

sortByLetter.js

ES6 根据字母表a-z,将字符数组归类排序 export const sortByAlphabet = (arr, key) => { if (!String.prototype.localeCompare) { console.error('浏览器不支持排序!') return } let letters = '*abcdefghjklmnopqrstwxyz'.split('') let zh = '阿八嚓哒妸发旮哈讥咔垃痳拏噢妑七呥扨它穵夕丫帀'.split('') let segs = [] let curr let isZhCn = /[\u4e00-\u9fa5]/ letters.forEach((letter, i) => { curr = {groupName: letter, children: []} arr.forEach((hanzi) => { let mingzi = key === undefined ? hanzi : hanzi[key] // 中文为首 if (isZhCn.test(mingzi[0])) { let qianHz = zh[i - 1] let xianHz = zh[i] if (!qianHz || (qianHz.localeCompare(mingzi) <= 0 && mingzi.localeCompare(xianHz) === -1)) { curr.children.push(hanzi) } } else { // 英文为首 let qianHz = letters[i] let xianHz = letters[i + 1] if (!qianHz || (qianHz.localeCompare(mingzi) <= 0 && mingzi.localeCompare(xianHz) === -1)) { curr.children.push(hanzi) } } }) if (curr.children.length > 0) { curr.children.sort((a, b) => { if (key !== undefined) return a[key].localeCompare(b[key]) return a.localeCompare(b) }) } if (curr.groupName !== '*') segs.push(curr) }) return segs }

2020-01-09

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除