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

前端开发 作者: 2024-08-20 18:30:02
工作中经常会遇到这样的需求:1.购物车列表中勾选某些,点击任意一项,前往详情页,再返回购物车依旧需要呈现勾选状态2.勾选人员后,前往别的页面,再次返回,人员依旧程勾选状态3.等等.... 离开页面的时
数据结构如下:
// 缓存数据
var students = [
        { id: 35,name: '小明',age: 25,address: '环球中心',checked:true},{ id: 36,name: '杰伦',age: 41,address: '中国台湾',{ id: 37,name: '不撸死',age: 46,address: '霉国',1)">}
    ]
    
  最新数据
var data =false },{ id: 38,name: '大明',address: '哈哈哈哈哈',{ id: 39,name: '中明',address: '中国四川',1)">}
    ]
思路如下:
具体代码如下:
}
    ]
    
     将数组转换为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 = 
      }
      i++;
    }
     最终得到的data就是还原了勾选状态的数据,可以直接渲染在界面上
    console.log(data)
    
原创声明
本站部分文章基于互联网的整理,我们会把真正“有用/优质”的文章整理提供给各位开发者。本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
本文链接:http://www.jiecseo.com/news/show_65658.html