高效遍历匹配Json数据,避免嵌套循环[转]

工作中经常会遇到这样的需求:
1.购物车列表中勾选某些,点击任意一项,前往详情页,再返回购物车依旧需要呈现勾选状态
2.勾选人员后,前往别的页面,再次返回,人员依旧程勾选状态
3.等等....

数据结构如下:
// 缓存数据
var students = [
        { id: 35, name: ‘小明‘, age: 25, address: ‘环球中心‘,checked:true},
        { id: 36, name: ‘杰伦‘, age: 41, address: ‘中国台湾‘ ,checked:true},
        { id: 37, name: ‘不撸死‘, age: 46, address: ‘霉国‘ ,checked:true}
    ]

 // 最新数据
var data = [
        { id: 35, name: ‘小明‘, age: 25, address: ‘环球中心‘,checked:false },
        { id: 36, name: ‘杰伦‘, age: 41, address: ‘中国台湾‘ ,checked:false},
        { id: 37, name: ‘不撸死‘, age: 46, address: ‘霉国‘ ,checked:false},
        { id: 38, name: ‘大明‘, age: 46, address: ‘哈哈哈哈哈‘ ,checked:false},
        { id: 39, name: ‘中明‘, age: 46, address: ‘中国四川‘ ,checked:false}
    ]
思路如下:

离开页面的时候将勾选的数据缓存,再次返回到页面时,将最新添加的数据和缓存的数据做对比,如果缓存中存在勾选,则更改对应的最新数据。

在做数据比对的时候,可以通过嵌套for循环,一层for循环遍历最新数据,二层for循环遍历缓存数据,如果缓存数据中对应的checked为true,则更改第一层for循环对应的值。虽然通过嵌套循环可以实现效果,但是循环的次数是两个数组长度的乘积,当数据量大的时候,这样会很耗性能。这里推荐另一种办法,将缓存的数组转换成Json对象,将唯一的id作为数组中每一项的key,将数组的每一项做为value,这样循环的时候只需要一层循环即可

具体代码如下:
// 缓存数据
var students = [
        { id: 35, name: ‘小明‘, age: 25, address: ‘环球中心‘,checked:true },
        { id: 36, name: ‘杰伦‘, age: 41, address: ‘中国台湾‘ ,checked:true},
        { id: 37, name: ‘不撸死‘, age: 46, address: ‘霉国‘ ,checked:true}
    ]

 // 最新数据
var data = [
        { id: 35, name: ‘小明‘, age: 25, address: ‘环球中心‘,checked:false },
        { id: 36, name: ‘杰伦‘, age: 41, address: ‘中国台湾‘ ,checked:false},
        { id: 37, name: ‘不撸死‘, age: 46, address: ‘霉国‘ ,checked:false},
        { id: 38, name: ‘大名‘, age: 46, address: ‘哈哈哈哈哈‘ ,checked:false},
        { id: 39, name: ‘中明‘, age: 46, address: ‘中国四川‘ ,checked:false}
    ]

    // 将数组转换为json对象
function Array2Json(arr, obj = {}) {
        arr.forEach(item => {
            obj[item.id] = item;
        })

        return obj
    }

    students  = Array2Json(students);

    // 此处可以用for循环,但是推荐使用while,因为while比for效率高

    let i = 0;
    while (i < data.length) {
      if (students[data[i].id]) {
        data[i].checked = true
      }
      i++;
    }
    // 最终得到的data就是还原了勾选状态的数据,可以直接渲染在界面上
    console.log(data)
    

转载地址:https://segmentfault.com/a/1190000016281753

原文地址:https://www.cnblogs.com/moqiutao/p/9869231.html

时间: 2024-10-07 13:31:36

高效遍历匹配Json数据,避免嵌套循环[转]的相关文章

高效遍历匹配Json数据与双层for循环遍历Json数据

工作中往往遇到这种情况,保留用户操作痕迹,比如用户选择过得东西,用户进入其它页面再返回来用户选择的的数据还在. 比如:1.购物车列表中勾选某些,点击任意一项,前往详情页,再返回购物车依旧需要呈现勾选状态           2.勾选人员后,前往别的页面,再次返回,人员依旧程勾选状态           3.等等.... 解决方法:1.把用户选择的数据在本地保存一份 2.进入当前页面拿缓存数据和新数据(从后台获取的数据)进行对比,然后进行对比渲染 在做数据比对的时候,可以通过嵌套for循环,一层f

jQuery遍历多层json数据

1.json与jsonp的区别(待查) 2.要遍历的数据如下: {"status": "ok", "code": 200, "data": {"343946": {"8144": {"feed": 0, "instagram": 0, "livefyre": 21, "facebook": 0, "

for-in遍历json数据

1.for遍历json数据 var json = {'name':'wly','age':'22','fun':'前端开发'} for(var attr in json){ alert(json[attr]) //遍历json属性的数据 alert(json['name']) //访问单个json属性 } 2.for in 遍历对象属性 var str = ''; var num = 0; for(var attr in window){ str += num + '.'+ attr+':'+

laravel5.4 关于后台数组中数据和json数据在前台的遍历输出

字段 本人做汽车网站开发,开发一个新项目需要引入上w的车型和车部件在数据库,实现用户查询显示功能! 数据库设计 其中comprehensive_type是存放json格式的数据,里面包含该车型的各种信息! 大概内容是: {"car_info":{"sales_status":"在售","guide price":"66.80万","level":"中型SUV",&qu

JS 循环遍历JSON数据 分类: JS技术 JS JQuery 2010-12-01 13:56 43646人阅读 评论(5) 收藏 举报 jsonc JSON数据如:{&amp;quot;options&amp;quot;:&amp;quot;[{

JS 循环遍历JSON数据 分类: JS技术 JS JQuery2010-12-01 13:56 43646人阅读 评论(5) 收藏 举报 jsonc JSON数据如:{"options":"[{/"text/":/"王家湾/",/"value/":/"9/"},{/"text/":/"李家湾/",/"valu e/":/"10

最简单简洁高效的Json数据解析

一.无图无真相 二.主要代码 1.导入jar包 拷贝fastjson.jar包到projectlibs包下 2.封装工具类JsonUtil.java package com.example.parsejsondemo; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import java.util.List; /**

Android 读取 json 数据(遍历jsonarray和jsonboject)-FenGKun

Android 读取 json 数据(遍历jsonarray和jsonboject) public String getJson(){ String jsonString = "{\"FLAG\":\"flag\",\"MESSAGE\":\"SUCCESS\",\"name\":[{\"name\":\"jack\"},{\"name\"

JS 循环遍历JSON数据

JSON数据如:{"options":"[{/"text/":/"王家湾/",/"value/":/"9/"},{/"text/":/"李家湾/",/"value/":/"10/"},{/"text/":/"邵家湾/",/"value/":/"13/

jQuery遍历复杂的JSON数据

{"group_id_1":[{"groupd_id":"1","authority":{"19":"\u6d4f\u89c8\u6587\u7ae0","22":"\u5220\u9664\u6587\u7ae0","5":"\u6743\u9650\u7f16\u8f91","12":