麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

Javascript中JSON數據分組優化實踐及JS操作JSON總結

2019-11-19 14:40:15
字體:
來源:轉載
供稿:網友

現有一堆數據,我需要按時間進行分組,以便前端視圖呈現

[ {"date":"2017-12-22","start_time":"10:00:00","end_time":"10:00:00","status":"Performance Time"}, {"date":"2017-12-22","start_time":"10:40:00","end_time":"10:40:00","status":"Performance Time"}, {"date":"2017-12-23","start_time":"10:00:00","end_time":"10:00:00","status":"Performance Time"}, {"date":"2017-12-23","start_time":"10:40:00","end_time":"10:40:00","status":"Performance Time"}]

需轉化為如下

[ { date: '2017-12-22', data: [  {  date: '2017-12-22',  start_time: '10:00:00',  end_time: '10:00:00',  status: 'Performance Time'  },  {  date: '2017-12-22',  start_time: '10:40:00',  end_time: '10:40:00',  status: 'Performance Time'  } ] }, { date: '2017-12-23', data: [  {  date: '2017-12-23',  start_time: '10:00:00',  end_time: '10:00:00',  status: 'Performance Time'  },  {  date: '2017-12-23',  start_time: '10:40:00',  end_time: '10:40:00',  status: 'Performance Time'  } ] }]

1.原始方法,網絡一大堆

var map = {}, nList = [] //遍歷原始數組 for (var i = 0; i < arr.length; i++) { var item = arr[i] //如果map沒有則在新nList中添加 if (!map[item.date]) {  nList.push({  date: item.date,  data: [item]  })  map[item.date] = item } else {  //遍歷nList  for (var j = 0; j < nList.length; j++) {  var nItem = nList[j]、  //如查找到date符合則添加  if (nItem.date == item.date) {   nItem.data.push(item)   //跳出循環   break  }  } } }

運行效率:遍歷1000個約3ms,總覺得不優雅,而且沒用到ES5的特性,于是決定自己優化一下!

2.使用ES5特性

將for替換為forEach和every

let map = {}, nList = [] arr.forEach((item) => { if (!map[item.date]) {  nList.push({  date: item.date,  data: [item]  })  map[item.date] = item } else {  //因為forEach不支持break,所以使用every實現  nList.every((nItem) => {  if (nItem.date === item.date) {   nItem.data.push(item)   return false  }  return true  }) } })

性能優化50%,約1.5ms!

3.性能優化實踐

因為我的數組中的date是按 順序排列 ,而且沒有重復,這樣可以考慮 去除第二個循環

let map = {}, nList = [] //設置初始key為0 let _nkey = 0 arr.forEach((item, index) => { if (index === 0) {  nList.push({  date: item.date,  data: [item]  }) } else {  let oItem = arr[index - 1]  //和前一個date一致則在當前添加,否則添加至nList  if (item.date === oItem.date) {  nList[_nkey]['data'].push(item)  } else {  nList.push({   date: item.date,   data: [item]  })  _nkey ++  } } })

效率再次優化50%,約1ms!

PS:JS操作JSON總結

JSON(JavaScript Object Notation) 是一種輕量級的數據交換格式,采用完全獨立于語言的文本格式,是理想的數據交換格式。同時,JSON是 JavaScript 原生格式,這意味著在 JavaScript 中處理 JSON數據不須要任何特殊的 API 或工具包。

    本文主要是對JS操作JSON的要領做下總結。

    在JSON中,有兩種結構:對象和數組。

    1. 一個對象以“{”(左括號)開始,“}”(右括號)結束。每個“名稱”后跟一個“:”(冒號);“‘名稱/值' 對”之間運用 “,”(逗號)分隔。 名稱用引號括起來;值如果是字符串則必須用括號,數值型則不須要。例如: 

var o={"xlid":"cxh","xldigitid":123456,"topscore":2000,"topplaytime":"2009-08-20"};

    2. 數組是值(value)的有序集合。一個數組以“[”(左中括號)開始,“]”(右中括號)結束。值之間運用 “,”(逗號)分隔。

    例如:

  var jsonranklist=[{"xlid":"cxh","xldigitid":123456,"topscore":2000,"topplaytime":"2009-08-20"},{"xlid":"zd","xldigitid":123456,"topscore":1500,"topplaytime":"2009-11-20"}];

    為了方便地處理JSON數據,JSON提供了json.js包,下載地址:http://www.json.org/json.js

    在數據傳輸流程中,json是以文本,即字符串的形式傳遞的,而JS操作的是JSON對象,所以,JSON對象和JSON字符串之間的相互轉換是關鍵。例如:

    JSON字符串:

  var str1 = '{ "name": "cxh", "sex": "man" }';

    JSON對象:   

 var str2 = { "name": "cxh", "sex": "man" };

    一、JSON字符串轉換為JSON對象

    要運用上面的str1,必須運用下面的要領先轉化為JSON對象:

  //由JSON字符串轉換為JSON對象var obj = eval('(' + str + ')');

或者  

var obj = str.parseJSON(); //由JSON字符串轉換為JSON對象

    或者 

  var obj = JSON.parse(str); //由JSON字符串轉換為JSON對象

    然后,就可以這樣讀?。?/p>

  Alert(obj.name);  Alert(obj.sex);

    特別留心:如果obj本來就是一個JSON對象,那么運用 eval()函數轉換后(哪怕是多次轉換)還是JSON對象,但是運用 parseJSON()函數處理后會有疑問(拋出語法異常)。

    二、可以運用 toJSONString()或者全局要領 JSON.stringify()將JSON對象轉化為JSON字符串。

    例如:   

var last=obj.toJSONString(); //將JSON對象轉化為JSON字符

    或者

  var last=JSON.stringify(obj); //將JSON對象轉化為JSON字符  alert(last);

    留心:

    上面的多個要領中,除了eval()函數是js自帶的之外,其他的多個要領都來自json.js包。新版本的 JSON 修改了 API,將 JSON.stringify() 和 JSON.parse() 兩個要領都注入到了 Javascript 的內建對象里面,前者變成了 Object.toJSONString(),而后者變成了 String.parseJSON()。如果提示找不到toJSONString()和parseJSON()要領,則說明您的json包版本太低。



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 午夜看毛片 | av日韩在线免费观看 | 亚洲一区二区三区高清 | 黄色99视频 | 在线播放污 | 少妇一级淫片免费放4p | 成人在线视频在线观看 | 最新av网址在线观看 | 最近中文字幕一区二区 | 国产成人强伦免费视频网站 | 一级国产精品一级国产精品片 | 天天草天天干天天 | 免费人成年短视频在线观看网站 | 午夜精品久久久久久中宇 | 成人免费观看在线视频 | 牛牛a级毛片在线播放 | 国产欧美日韩视频在线观看 | 一级成人黄色片 | 性少妇chinesevideo | 黄色片网站在线看 | 毛片视频免费观看 | 欧美一级特黄aaaaaaa什 | 91精品国产91久久久 | 91久久久久久久一区二区 | 性生活视频软件 | 国产日韩在线观看视频 | 精品亚洲在线 | 国产一区二区三区四区五区在线 | 欧产日产国产精品v | 国产做爰全免费的视频黑人 | av成人免费看 | 女教师~淫辱の动漫在线 | 91精品福利视频 | 蜜桃视频日韩 | v11av在线视频成人 | 九九热视频这里只有精品 | 亚洲视频在线观看免费视频 | 黄色电影免费网址 | 久久毛片免费 | 欧美性生活区 | 欧美日韩国产成人在线观看 |