Array及JSON的操作
Array的操作
JavaScript的Array是non typed的,即每個成員可以type不一樣,跟Object一樣.
Array裡的單一元素操作, 其取出copy到另一變數時遵照一般的規則
移除第一個元素以及最後一個元素
Array的copy (array本身是reference type)
array2等於array1, 透過array2改, 印出array1也被改到
Array的deep copy/clone/duplicate (copy each element)
使用 slice()
http://www.w3schools.com/jsref/jsref_slice_array.asp
slice()
另一用途: 用來取某一部份的array的值, e.g. slice(1,3)
, 從1取到2.
Array的 For-Loop
有兩種
Iterator, e.g.
for student of students
for (var i=0; i< 100; i++)
ES6才有array的for-of
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/for...of,
ES5的array要用 int i = 0
的方法.
遞迴(Recursion)
算是除了loop/iterationg以外另一種實現方式.
可練習
在很多語言裡是比較慢的. 有些語言可能較快. 可參考 http://stackoverflow.com/questions/2651112/is-recursion-ever-faster-than-looping
JavaScript的遞迴跟大多數一樣, 是比loop慢的, http://stackoverflow.com/questions/9474465/is-iteration-faster-than-recursion-or-just-less-prone-to-stack-overflows
Array的high order function操作map, filter, reduce
建議若可以用這些語言內建的function, 盡量用, 因為本身通常都有優化過, 較快. 參考上面的Link http://stackoverflow.com/questions/2651112/is-recursion-ever-faster-than-looping
map(很常見): 對每一個元素做處理, 形成新array. [https://msdn.microsoft.com/zh-tw/library/ff679976(v=vs.94).aspx](https://msdn.microsoft.com/zh-tw/library/ff679976(v=vs.94).aspx)
e.g.
filter: 對每一個元素做篩選, 形成新array [https://msdn.microsoft.com/zh-tw/library/ff679973(v=vs.94).aspx](https://msdn.microsoft.com/zh-tw/library/ff679973(v=vs.94).aspx)
reducer: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/Reduce The reduce() method applies a function against an accumulator and each value of the array (from left-to-right) to reduce it to a single value.
JSON的注意事項及常見處理
JSON (JavaScript Object Notation)為從JavaScript Object推廣而來的一種資料格式,JSON本身是代表JavaScript物件的標記方法,而JavaScript Object的簡化型 (無function,純value type) 就是對應到此種資料格式,故JSON同時有兩種意思。JSON在其他語言可能名字是Map/KeyValue/Dictionary. 跟Array一樣為兩大常見的資料形態.
如何access其property對應到的值或物件:
data.name
data["name"]
var key="name"; data[key];
如何事先檢查property有無存在 (通常會在上述第1點前檢查), 如果不檢查則
var nameValue = data.name; //undefined
,事後用可能exception或logic不符合if(data.name){}
如果物件沒有name這個property, 不會進去. 會連它的prototype都查, 若要知道prototype, 請詳閱ES5中的自訂物件類型-prototype一章,data.hasOwnProperty(name)
, 介紹:https://developer.mozilla.org/zh-TW/docs/Web/JavaScript/Reference/Global_Objects/Object/hasOwnProperty. 而根據 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Inheritance_and_the_prototype_chain hasOwnProperty is the only thing in JavaScript which deals with properties and does not traverse the prototype chain. 此方法不會查prototype chain, 所以在效能上比1.好,關於JavaScript的prototype可參考進階-再講prototype一章
for-in
, https://developer.mozilla.org/zh-TW/docs/Web/JavaScript/Reference/Statements/for...in 找出一個一個key, 然後就可以obj[key]列出每一個value做處理.Object.keys(data)
. 把全部key都存成一個array. https://developer.mozilla.org/zh-TW/docs/Web/JavaScript/Reference/Global_Objects/Object/keysdeepCopy每對key/value到新object. 使用
Object.assign
https://developer.mozilla.org/zh-TW/docs/Web/JavaScript/Reference/Global_Objects/Object/assign
常見case - Loop Array 或 JSON/Map/Dictionary 時要小心的事情
有一個常見的use case是: 一個Array要挑出某個特定的element, 然後把它從這array裡移除掉. How?
Last updated