高效遍历匹配Json数据,避免嵌套循环[转]
2018-10-29 15:27:50来源:博客园 阅读 ()
工作中经常会遇到这样的需求:
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
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:js之作用域
下一篇:判断机型是否为iphoneX
- jquery遍历筛选数组的几种方法和遍历解析json对象 2020-02-29
- 高效率JavaScript编写技巧整理 2020-02-15
- 高效的获取当前元素是父元素的第几个子元素 2020-02-15
- 高效Web开发的10个jQuery代码片段 2020-02-15
- 高效的jQuery代码编写技巧总结 2020-02-15
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash