数据结构就是这样的地区json。现在有个需求,就是给我一个RegionId,我要找到他本身以及他所有的直系父辈的RegionId,并且放入一个数组中。找到这个RegionId这一级很容易,但是怎么找到所有的直系父辈的RegionId让我有点头疼。有没有大佬会的。。。
2条回答 默认 最新
- Okay6 2019-06-06 17:03关注
// 调用方法,入参:JSON数组,RegionId 返回:JSON对象,target ->regionId对应对象/parentArray - >直系父对象数组 function search(searchObjectList,regionId){ this.parentSearchObjectList = searchObjectList this.target = null this.parentArray = new Array() findTarget(searchObjectList,regionId) return {'target' : target,'parentArray':parentArray} //返回查找结果 } //寻找目标对象 function findTarget(objectList, regionId) { var parentId = null for (i = 0; i < objectList.length; i++) { let o = objectList[i] if (o['RegionId'] == regionId) { target = o parentId = o['ParentId'] if (parentId != "") { return findParent(this.parentSearchObjectList, parentId); } else { return } } else { childList = o['Children'] if (childList.length > 0) { return findTarget(childList,regionId ) } } } } //寻找目标对象直系父对象 function findParent(objectList, parentId) { for (i = 0; i < objectList.length; i++) { let o = objectList[i] if (o['RegionId'] == parentId) { parentArray.push(o) } else { childList = o['Children'] if (childList.length > 0) { return findParent(childList, parentId) } } } }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 idea自动补全键位冲突
- ¥15 iis10中如何阻止别人网站重定向到我的网站
- ¥15 滑块验证码移动速度不一致问题
- ¥15 定制ai直播实时换脸软件
- ¥100 栈回溯相关,模块加载后KiExceptionDispatch无法正常回溯了
- ¥15 Utunbu中vscode下cern root工作台中写的程序root的头文件无法包含
- ¥15 麒麟V10桌面版SP1如何配置bonding
- ¥15 Marscode IDE 如何预览新建的 HTML 文件
- ¥15 K8S部署二进制集群过程中calico一直报错
- ¥15 java python或者任何一种编程语言复刻一个网页