1.使用對象字面量定義對象
var person={};
使用這種方式建立對象時,實際上不會調用object構造函數。
開發人員更喜歡對象字面量的文法。
2.有時候需要傳遞大量可選參數的情形時,一般來講使用對象字面量來封裝多個可選參數。
3.對象屬性的點表示法與方括号表示法的差別
(1)功能上:兩者沒差別
(2)但是方括号的有點是可以通過變量來通路屬性
例如:
var person={
name:"nic"
}
點表示法:person.name
方括号表示法:var prop=“name”;
person[prop]
(3)還有一個優點是:
如果屬性名中包含會導緻文法錯誤的字元或者關鍵字,保留字時候,使用方括号不會錯
例如:person["first name"]="ok";
(4)通常,建議使用點表示法
4.建立數組的問題
這是因為ie8及之前的版本在實作數組字面量方面有bug
使用字面量建立數組時,不會調用array構造函數。
5.如果設定某個值的索引超過了數組現有項數。
如:var color=[1,2,3]
color[3]時,數組會自動增加到該索引值加1的長度
這時,color[3]的值就是undefined
6.數組的length不隻是隻讀的。通過設定length該屬性,可以不斷向數組末尾添加新項。
7.數組轉換成字元串 tostring() join()
8.數組的棧方法 push() pop()
棧是一種資料結構,也就是最新添加的項最早被移除(後進先出)。而棧中項的插入和移除,隻發生在一個位置--棧的頂部。
ecmascript提供了push()與pop()方法來實作這種棧。
push() 方法可向數組的末尾添加一個或多個元素,并傳回新的長度。
pop() 方法用于删除并傳回數組的最後一個元素。
例子:
9.隊列方法 shift() unshift()
隊列資料的通路規則是先進先出
ecmascript提供了shift()來實作。
shift() 方法用于把數組的第一個元素從其中删除,并傳回第一個元素的值。
unshift() 方法可向數組的開頭添加一個或更多元素,并傳回新的長度。
10.重排序方法 sort() reverse()
ecmascript提供了sort()與reverse()來實作。
sort()會調用每個數組項的tostring()方法,比較得到的字元串來排序。
11.數組的拼接 concat()
concat() 方法用于連接配接兩個或多個數組。
該方法不會改變現有的數組,而僅僅會傳回被連接配接數組的一個副本。
12.slice() 方法可從已有的數組中傳回標明的元素。
13.位置方法:indexof()與lastindexof()
14.疊代方法
ecmascript5定義了下列5種方法,該5種方法都接收三個參數:數組項的值,該項在數組中的位置,數組對象本身
every(),filter(),foreach(),map(),some()
![](https://img.laitimes.com/img/9ZDMuAjOiMmIsIjOiQnIsIiZpdmLlR2bjlHcvN2LcNXZnFWbp9CXt92YuM3ZvxmYuNmLu9Wbt92Yvw1LcpDc0RHaiojIsJye.gif)
![](https://img.laitimes.com/img/9ZDMuAjOiMmIsIjOiQnIsIiZpdmLlR2bjlHcvN2LcNXZnFWbp9CXt92YuM3ZvxmYuNmLu9Wbt92Yvw1LcpDc0RHaiojIsJye.gif)
轉載:http://www.cnblogs.com/zqzjs/p/5008628.html