国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - 關(guān)于這組數(shù)據(jù)如何實現(xiàn) 按字母列表分類展示 不改動數(shù)據(jù)結(jié)構(gòu)

瀏覽:149日期:2022-12-05 08:23:25

問題描述

var data = [{ 'name': '渦陽', 'pinyin': 'WoYang'}, { 'name': '邳州', 'pinyin': 'PiZhou'}, { 'name': '玉溪', 'pinyin': 'YuXi'}, { 'name': '無錫', 'pinyin': 'WuXi'}, { 'name': '萍鄉(xiāng)', 'pinyin': 'PingXiang'}];

按照字母 A B C ...列表歸類 如

P-> { 'name': '萍鄉(xiāng)', 'pinyin': 'PingXiang' }, { 'name': '邳州', 'pinyin': 'PiZhou' }

類似鏈接描述

怎么操作這組數(shù)據(jù)。。

我的代碼,比較渣 求更優(yōu)雅的寫法function jsfu(data) { var obj={} data.map(function(item, index) {let codeIndex = item.pinyin.charAt(0)if (!obj[codeIndex]) { obj[codeIndex] = {item: [] }} obj[codeIndex].item.push(item) }) return obj}怎么排序,發(fā)現(xiàn)在頁面是無序的,是js對象無序特性!

問題解答

回答1:

function jsfu(data) { var map = {} , arr = [] , dest = [] for (let i = 0; i < data.length; i++) {arr.push({ code: data[i].pinyin.charAt(0), item: data[i]}) } for (let i = 0; i < arr.length; i++) {if (!map[arr[i].code]) { dest.push({code: arr[i].code,item: [arr[i].item] }) map[arr[i].code] = arr[i].code} else { for (let j = 0; j < dest.length; j++) {if (dest[j].code == arr[i].code) { dest[j].item.push(arr[i].item); break;} }} } //排序 dest.sort(function(a, b) {if (a.code > b.code) { return 1;}if (a.code < b.code) { return -1;}return 0; }) return dest}jsfu(data)

[ {'code': 'P','item': [ {'name': '邳州','pinyin': 'PiZhou' }, {'name': '萍鄉(xiāng)','pinyin': 'PingXiang' }] }, {'code': 'W','item': [ {'name': '渦陽','pinyin': 'WoYang' }, {'name': '無錫','pinyin': 'WuXi' }] }, {'code': 'Y','item': [ {'name': '玉溪','pinyin': 'YuXi' }] }]回答2:

data = data.sort(function(a, b) { return a.pinyin[0].localeCompare(b.pinyin[0])})console.log(JSON.stringify(data))

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 大理市| 乐安县| 铜山县| 元朗区| 绥棱县| 天祝| 蒲江县| 兴和县| 信阳市| 高阳县| 嵊泗县| 临海市| 蒙城县| 罗源县| 治多县| 通海县| 红安县| 四川省| 万载县| 安平县| 县级市| 西昌市| 莆田市| 郑州市| 塘沽区| 开化县| 中阳县| 墨脱县| 瓮安县| 寿宁县| 日喀则市| 洱源县| 神木县| 甘德县| 凤城市| 新巴尔虎左旗| 安塞县| 涿州市| 马公市| 增城市| 梁山县|