前端解析不了数组,求大神们告知如何解决

本贴最后更新于 2821 天前,其中的信息可能已经渤澥桑田

今天前端告诉我因为产品告诉她角色树层数不限层数(之前告诉她最多四层),所以她那边没法解析我给她的数组了,如果我这边把数组的某几个字段改一下,她可以用一个插件来解析。然后我这边需要把之前的 roleTreeDTO 改名叫 children, 原来的 roleId 要改成 key,以方便她套用那个插件。

虽说把 DTO 改成那样不符合代码规范,但终究只是名字问题,然而 key 作为一个 sql 的保留字段,我这边一改就得报错了。然后我只能遗憾的告诉她这个 key 字段没法改,然后问她之前是怎么获取数组的,她告诉我是套嵌四个 for 循环......我不是很懂前端,所以在此帮我的前端同事问一下有没有好的方法解决。

我的数据结构是这样的:

{ "rc": 0, "ret": { "children": [ { "children": [ { "children": [], "roleId": 3, "roleName": "系统管理员", "description": null }, { "children": [], "roleId": 4, "roleName": "麻瓜管理员", "description": null }, { "children": [], "roleId": 6, "roleName": "超级管理员", "description": "拥有全部权限的角色" } ], "roleId": 1, "roleName": "管理员", "description": null }, { "children": [ { "children": [], "roleId": 7, "roleName": "技术员", "description": "可以查看数据的角色" }, { "children": [], "roleId": 11, "roleName": "领导", "description": "用于糊弄的角色" } ], "roleId": 2, "roleName": "一般用户", "description": null }, { "children": [], "roleId": 8, "roleName": "测试删除", "description": "用于测试删除的用户组" } ], "roleId": null, "roleName": null, "description": null }, "err": null }

上面是我传给前端的 json,希望大神提出宝贵的意见和方案,谢谢

  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    730 引用 • 1280 回帖
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    246 引用 • 1338 回帖
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    52 引用 • 190 回帖
  • 工作

    快乐工作,认真生活。

    140 引用 • 1473 回帖 • 6 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • 88250

    我解析你的正文有困难

    2 回复
  • Eddie

    笑死 😆

  • Eddie

    key 是保留字?不能加 as "key"吗?

  • Vanessa via macOS

    不知道你们前端用的什么插件。这样应该已经满足很多插件的结构了

    1 回复
  • DrJoseph
    作者

    好像是一个叫 table 的表格

    1 回复
  • DrJoseph
    作者

    表达有待提高 😂

    1 回复
  • 88250

    主要是排版问题

    1 回复
  • DrJoseph
    作者

    我先去看看 Markdown 文档改下格式吧

    1 回复
  • 88250

    右上角头像下拉帮助里面有

  • FlyingFinger

    😅 好多层~~~

  • Vanessa via macOS

    叫 table 的表格有很多。不同的框架都有好几个叫 table 的表哥。。。😳

    1 回复
  • DrJoseph
    作者

    她也只是告诉我那个叫 table,我也是一脸懵逼

  • DrJoseph
    作者

    @participants 最新消息,前端告诉我她已经解决了,虽然如果角色层数多会消耗一定的效率,但是也算是解决了产品出的难题 😊

    1 回复
  • Vanessa via macOS

    搞定就好。不行就异步获取

  • FlyingFinger

    这个问题一会儿得去问问老师,趁着有老师赶紧解决了 ~ 😆

    1 回复
  • 88250

    我还在纠结要不要帮楼主排一下版

    1 回复
  • DrJoseph
    作者

    可能是还没适应公司的工作氛围吧,想着自己钻研,如果时间允许的情况下还是挺好的

  • DrJoseph
    作者

    我先试着改改吧 😨

  • someone756 via macOS

    我的哥,不会格式化一下代码么...

    1 回复
  • DrJoseph
    作者

    老哥,问题已经解决了,谢谢提醒,下次注意 😆

    1 回复
  • FlyingFinger

    好奇,怎么解决的分享下思路呗

    1 回复
  • wizardforcel

    反正你们两个至少有一个人需要写代码处理 JSON。理论上前端应该做这事。

    1 回复
  • DrJoseph
    作者

    这个我没问前端...只是她告诉我她那边找到方法解决了

    1 回复
  • FlyingFinger

    😂心理痒痒的。。。。。哎

    1 回复
  • DrJoseph
    作者

    等中午休息的时候我问问看吧

    1 回复
  • FlyingFinger

    谢了哈~ 😏

    2 回复
  • DrJoseph
    作者

    不用客气 😆

  • DrJoseph
    作者

    主要是前端那边进展不顺的话会延误时间,前后端交接算双方的工作之一,如果任务节点时间延误会影响绩效,所以希望能帮前端想想办法

  • DrJoseph
    作者

    中午问了我们前端,她说循环用的是递归,生成树状结构是用 antd 和 Tree 的组件

    1 回复
  • FlyingFinger

    前者递归可以理解,后面的组件没用过,回头瞅瞅 ~ 再有一个月就该找工作了

  • 88250 1

    @participants 实在忍不住帮楼主重新排版了一下

    3 回复
  • FlyingFinger

    滋滋,看着舒服多了~ 😏

  • Vanessa via macOS

    滋滋,看着舒服多了 ~

    1 回复
  • FlyingFinger

    😱这个 big 怎么玩?

    1 回复
  • Vanessa via macOS

    command + c and command + v

    1 回复
  • FlyingFinger

    7abd2c4f96124c9abe8c95ee747fb633-image.png

    滋滋,看看效果,应该不错的~

    1 回复
  • Vanessa via macOS

    放这么大干嘛? 背景透明就更好了

    1 回复
  • FlyingFinger

    没注意啊,笔记本改换了,白色要掰着看才能看出来 😆

  • DrJoseph
    作者

    辛苦 D 大了 😁嘻嘻

    1 回复
  • 88250

    记得熟悉 Markdown 啊

    1 回复
  • DrJoseph
    作者

    收到 👌

  • wizardforcel

请输入回帖内容 ...

推荐标签 标签

  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖
  • 代码片段

    代码片段分为 CSS 与 JS 两种代码,添加在 [设置 - 外观 - 代码片段] 中,这些代码会在思源笔记加载时自动执行,用于改善笔记的样式或功能。

    用户在该标签下分享代码片段时需在帖子标题前添加 [css] [js] 用于区分代码片段类型。

    170 引用 • 1150 回帖
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    174 引用 • 539 回帖
  • CAP

    CAP 指的是在一个分布式系统中, Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可兼得。

    12 引用 • 5 回帖 • 630 关注
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    345 引用 • 748 回帖
  • WebComponents

    Web Components 是 W3C 定义的标准,它给了前端开发者扩展浏览器标签的能力,可以方便地定制可复用组件,更好的进行模块化开发,解放了前端开发者的生产力。

    1 引用 • 8 关注
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    5 引用 • 7 回帖 • 2 关注
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 32 回帖
  • 笔记

    好记性不如烂笔头。

    310 引用 • 794 回帖 • 1 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖 • 7 关注
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    230 引用 • 1454 回帖 • 1 关注
  • ngrok

    ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。

    7 引用 • 63 回帖 • 650 关注
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    133 引用 • 1124 回帖 • 107 关注
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 29 关注
  • 机器学习

    机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。

    83 引用 • 37 回帖
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    42 引用 • 130 回帖 • 249 关注
  • SMTP

    SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。

    4 引用 • 18 回帖 • 634 关注
  • DNSPod

    DNSPod 建立于 2006 年 3 月份,是一款免费智能 DNS 产品。 DNSPod 可以为同时有电信、网通、教育网服务器的网站提供智能的解析,让电信用户访问电信的服务器,网通的用户访问网通的服务器,教育网的用户访问教育网的服务器,达到互联互通的效果。

    6 引用 • 26 回帖 • 530 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 48 关注
  • PWL

    组织简介

    用爱发电 (Programming With Love) 是一个以开源精神为核心的民间开源爱好者技术组织,“用爱发电”象征开源与贡献精神,加入组织,代表你将遵守组织的“个人开源爱好者”的各项条款。申请加入:用爱发电组织邀请帖
    用爱发电组织官网:https://programmingwithlove.stackoverflow.wiki/

    用爱发电组织的核心驱动力:

    • 遵守开源守则,体现开源&贡献精神:以分享为目的,拒绝非法牟利。
    • 自我保护:使用适当的 License 保护自己的原创作品。
    • 尊重他人:不以各种理由、各种漏洞进行未经允许的抄袭、散播、洩露;以礼相待,尊重所有对社区做出贡献的开发者;通过他人的分享习得知识,要留下足迹,表示感谢。
    • 热爱编程、热爱学习:加入组织,热爱编程是首当其要的。我们欢迎热爱讨论、分享、提问的朋友,也同样欢迎默默成就的朋友。
    • 倾听:正确并恳切对待、处理问题与建议,及时修复开源项目的 Bug ,及时与反馈者沟通。不抬杠、不无视、不辱骂。
    • 平视:不诋毁、轻视、嘲讽其他开发者,主动提出建议、施以帮助,以和谐为本。只要他人肯努力,你也可能会被昔日小看的人所超越,所以请保持谦虚。
    • 乐观且活跃:你的努力决定了你的高度。不要放弃,多年后回头俯瞰,才会发现自己已经成就往日所仰望的水平。积极地将项目开源,帮助他人学习、改进,自己也会获得相应的提升、成就与成就感。
    1 引用 • 487 回帖 • 5 关注
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3455 回帖 • 158 关注
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 555 关注
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖 • 5 关注
  • OnlyOffice
    4 引用 • 22 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖 • 3 关注