欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Javascript中JSON數(shù)據(jù)分組優(yōu)化實踐及JS操作JSON總結(jié)

 更新時間:2017年12月22日 08:59:21   作者:XANK  
這篇文章主要介紹了Javascript中JSON數(shù)據(jù)分組優(yōu)化實踐,文中還對JS操作JSON的要領(lǐng)做了總結(jié),需要的朋友可以參考下

現(xiàn)有一堆數(shù)據(jù),我需要按時間進(jìn)行分組,以便前端視圖呈現(xiàn)

[
 {"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"}
]

需轉(zhuǎn)化為如下

[
 {
 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.原始方法,網(wǎng)絡(luò)一大堆

var map = {},
 nList = []
 //遍歷原始數(shù)組
 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)
   //跳出循環(huán)
   break
  }
  }
 }
 }

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

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實現(xiàn)
  nList.every((nItem) => {
  if (nItem.date === item.date) {
   nItem.data.push(item)
   return false
  }
  return true
  })
 }
 })

性能優(yōu)化50%,約1.5ms!

3.性能優(yōu)化實踐

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

let map = {},
 nList = []
 //設(shè)置初始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一致則在當(dāng)前添加,否則添加至nList
  if (item.date === oItem.date) {
  nList[_nkey]['data'].push(item)
  } else {
  nList.push({
   date: item.date,
   data: [item]
  })
  _nkey ++
  }
 }
 })

效率再次優(yōu)化50%,約1ms!

PS:JS操作JSON總結(jié)

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

    本文主要是對JS操作JSON的要領(lǐng)做下總結(jié)。

    在JSON中,有兩種結(jié)構(gòu):對象和數(shù)組。

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

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

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

    例如:

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

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

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

    JSON字符串:

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

    JSON對象:   

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

    一、JSON字符串轉(zhuǎn)換為JSON對象

    要運用上面的str1,必須運用下面的要領(lǐng)先轉(zhuǎn)化為JSON對象:

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

或者  

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

    或者 

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

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

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

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

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

    例如:   

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

    或者

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

    留心:

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



相關(guān)文章

  • uniapp封裝小程序雷達(dá)圖組件的完整代碼

    uniapp封裝小程序雷達(dá)圖組件的完整代碼

    組件是一個單獨且可復(fù)用的功能模塊的封裝,每個組件,包括如下幾個部分:以組件名稱為標(biāo)記的開始標(biāo)簽和結(jié)束標(biāo)簽、組件內(nèi)容、組件屬性、組件屬性值,這篇文章主要給大家介紹了關(guān)于uniapp封裝小程序雷達(dá)圖組件的相關(guān)資料,需要的朋友可以參考下
    2021-07-07
  • JavaScript實現(xiàn)Tab點擊切換

    JavaScript實現(xiàn)Tab點擊切換

    這篇文章主要為大家詳細(xì)介紹了JavaScript實現(xiàn)Tab點擊切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • javascript將DOM節(jié)點添加到文檔的方法實例分析

    javascript將DOM節(jié)點添加到文檔的方法實例分析

    這篇文章主要介紹了javascript將DOM節(jié)點添加到文檔的方法,對比分析了javascript的兩種節(jié)點創(chuàng)建的方法,涉及javascript節(jié)點操作及運行時間計算的相關(guān)技巧,需要的朋友可以參考下
    2015-08-08
  • 使用JQuery進(jìn)行跨域請求

    使用JQuery進(jìn)行跨域請求

    JQuery 進(jìn)行跨域請求實現(xiàn)代碼,需要的朋友可以參考下。
    2010-01-01
  • JavaScript數(shù)據(jù)存儲 Cookie篇

    JavaScript數(shù)據(jù)存儲 Cookie篇

    這篇文章主要為大家介紹了JavaScript數(shù)據(jù)存儲 Cookie篇,感興趣的朋友可以參考一下
    2016-07-07
  • Javascript動畫效果(2)

    Javascript動畫效果(2)

    這篇文章主要為大家詳細(xì)介紹了第二篇Javascript動畫效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • JavaScript動態(tài)綁定詳解

    JavaScript動態(tài)綁定詳解

    這篇文章主要為大家詳細(xì)介紹了JavaScript動態(tài)綁定,關(guān)于JavaScript中為元素綁定的事件失效的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • js分頁之前端代碼實現(xiàn)和請求處理

    js分頁之前端代碼實現(xiàn)和請求處理

    這篇文章主要為大家詳細(xì)介紹了js分頁之前端代碼實現(xiàn)和請求處理,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 原生js封裝的ajax方法示例

    原生js封裝的ajax方法示例

    這篇文章主要介紹了原生js封裝的ajax方法,結(jié)合實例形式分析了JavaScript封裝ajax操作及調(diào)用方法相關(guān)操作技巧,非常簡單實用,需要的朋友可以參考下
    2018-08-08
  • Bootstrap每天必學(xué)之導(dǎo)航條(二)

    Bootstrap每天必學(xué)之導(dǎo)航條(二)

    Bootstrap每天必學(xué)之導(dǎo)航條,進(jìn)一步向大家講解了導(dǎo)航條養(yǎng)殖,以及導(dǎo)航條中元素的使用方法,感興趣的小伙伴們可以參考一下
    2016-03-03

最新評論