js 数组 IndexBar 索引栏字母顺序问题

发布于 2022-09-13 00:50:24 字数 707 浏览 28 评论 0

data = {
  D: [{...}],
  L: [{...}],
  Q: [{...}],
  S: [{...}],
  W: [{...}],
  X: [{...}],
  Z: [{...}]
}
       <van-index-bar class="anchorBar">
          <template v-for="(item, index) in data">
            <van-index-anchor :index="index" :key="index" />
            <van-cell
              center
              v-for="(item2, index2) in item"
              :key="index2"
              :title="item2.realName"
              :label="item2.userPost">
            </van-cell>
          </template>
        </van-index-bar>

请问一下后端按字母顺序给我返回的数据,循环遍历字母顺序错乱的。我哪里写错了吗?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

〗斷ホ乔殘χμё〖 2022-09-20 00:50:24

你的data是一个object对象,而object对象是无序的,你在浏览器看到的排序是浏览器按照自己的规则(一般是本地语言)进行的排序,这种情况需要对object进行处理,比如转成array后排序

一身仙ぐ女味 2022-09-20 00:50:24
const arr = [];
for (const key in data) {
    arr[key.charCodeAt()] = data[key];
}

可以先根据ASCII作为索引转成数组,使用时就反向变为字母。这样也省的排序了

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文