深入JavaScript高級程序設計之對象、數(shù)組(棧方法,隊列方法,重排序方法,迭代方法)
繼承是OO語言中的一個最為人津津樂道的概念。 許多OO語言都支持兩種繼承方式:接口繼承和實現(xiàn)繼承。 接口繼承只繼承方法簽名,而實現(xiàn)繼承則繼承實際的方法。 如其所述,由于函數(shù)沒有簽名,在ECMAScript中無法實現(xiàn)接口繼承。 ECMAScript只支持實現(xiàn)繼承,而且其實現(xiàn)繼承主要是依靠原型鏈來實現(xiàn)的。
1.使用對象字面量定義對象
var person={};
使用這種方式創(chuàng)建對象時,實際上不會調(diào)用Object構造函數(shù)。
開發(fā)人員更喜歡對象字面量的語法。
2.有時候需要傳遞大量可選參數(shù)的情形時,一般來講使用對象字面量來封裝多個可選參數(shù)。
3.對象屬性的點表示法與方括號表示法的區(qū)別
(1)功能上:兩者沒區(qū)別
(2)但是方括號的有點是可以通過變量來訪問屬性
例如:
var person={ name:"Nic" }
點表示法:person.name
方括號表示法:var prop=“name”;
person[prop]
(3)還有一個優(yōu)點是:
如果屬性名中包含會導致語法錯誤的字符或者關鍵字,保留字時候,使用方括號不會錯
例如:person["first name"]="OK";
(4)通常,建議使用點表示法
4.創(chuàng)建數(shù)組的問題
var colors=[1,2,] //不要這樣。這樣會創(chuàng)建一個包含2個或3個項的數(shù)組
var opy=[,,,,,] //不要這樣。這樣會創(chuàng)建一個包含5個或6個項的數(shù)組
這是因為IE8及之前的版本在實現(xiàn)數(shù)組字面量方面有bug
使用字面量創(chuàng)建數(shù)組時,不會調(diào)用Array構造函數(shù)
5.如果設置某個值的索引超過了數(shù)組現(xiàn)有項數(shù)。
如:var color=[1,2,3]
color[3]時,數(shù)組會自動增加到該索引值加1的長度
這時,color[3]的值就是undefined
6.數(shù)組的length不只是只讀的。通過設置length該屬性,可以不斷向數(shù)組末尾添加新項。
7.數(shù)組轉(zhuǎn)換成字符串 toString() join()
array.toString() //返回以逗號分隔的字符串 array.valueOf() //返回的還是數(shù)組 array.join(",") //也可以
8.數(shù)組的棧方法 push() pop()
棧是一種數(shù)據(jù)結構,也就是最新添加的項最早被移除(后進先出)。而棧中項的插入和移除,只發(fā)生在一個位置--棧的頂部。
ECMAScript提供了push()與pop()方法來實現(xiàn)這種棧。
push() 方法可向數(shù)組的末尾添加一個或多個元素,并返回新的長度。
pop() 方法用于刪除并返回數(shù)組的最后一個元素。
例子:
var arr=[]; var count=arr.push('a','b'); //count=2 arr.push('c'); var item=arr.pop(); //移除最后一項 c item=c 并且改變數(shù)組長度
9.隊列方法 shift() unshift()
隊列數(shù)據(jù)的訪問規(guī)則是先進先出
ECMAScript提供了shift()來實現(xiàn)。
shift() 方法用于把數(shù)組的第一個元素從其中刪除,并返回第一個元素的值。
unshift() 方法可向數(shù)組的開頭添加一個或更多元素,并返回新的長度。
10.重排序方法 sort() reverse()
ECMAScript提供了sort()與reverse()來實現(xiàn)。
sort()會調(diào)用每個數(shù)組項的tostring()方法,比較得到的字符串來排序。
11.數(shù)組的拼接 concat()
concat() 方法用于連接兩個或多個數(shù)組。
該方法不會改變現(xiàn)有的數(shù)組,而僅僅會返回被連接數(shù)組的一個副本。
12.slice() 方法可從已有的數(shù)組中返回選定的元素。
13.位置方法:indexOf()與lastIndexOf()
14.迭代方法
ECMAScript5定義了下列5種方法,該5種方法都接收三個參數(shù):數(shù)組項的值,該項在數(shù)組中的位置,數(shù)組對本身
every(),filter(),forEach(),map(),some()
例子:
var num=[1,2,3,4]; var res=num.every(function(item,index,array){ return (item>2) }) //false 必須每一項都大于2,才返回true var res=num.some(function(item,index,array){ return (item>2) }) //true 只要有一個大于2,就返回true var res=num.filter(function(item,index,array){ return (item>2) }) //[3,4] var res=num.forEach(function(item,index,array){ return (item>2) }) //[1,4,9,16]
javascript 數(shù)組對象中的迭代方法
/* javascript 數(shù)組對象中的迭代方法 * ECMAScript5為數(shù)組定義了5個迭代方法。每個方法都接受兩個參數(shù),第一個是進行迭代的函數(shù),第二個是該函數(shù)的作用域?qū)ο蟆究蛇x】。 * 進行迭代的函數(shù)接受三個參數(shù),第一個是數(shù)組中要進行迭代的元素的值,第二個是數(shù)組候總要進行迭代的元素的位置,第三個是迭代數(shù)組本身。 * 1. every() 對數(shù)組中的每一項運行給定的函數(shù),如果該函數(shù)對每一項都返回true,則返回true * 2. filter() 對數(shù)組中的每一項運行給定的函數(shù),返回該函數(shù)返回true的項組成的數(shù)組。 * 3. forEach() 對數(shù)組中的每一項運行給定的函數(shù),這個方法沒有返回值 * 4. map() 對數(shù)組中的每一項運行給定的函數(shù),返回每次函數(shù)調(diào)用的結果組成的數(shù)組 * 5. some() 對數(shù)組中的每一項運行給定的函數(shù),如果該函數(shù)對任意一項返回true,則返回true * * 這些迭代方法支持的瀏覽器有,IE9+,F(xiàn)irefox2+,Safari3+,Opera 9.5+,chrome */ var num = [1,2,3,4,5,6,7,8,9]; var everyResult = num.every(function(item, index, array) { if(item > 2) { return true; } }); alert(everyResult); var someResult = num.some(function(item) { if(item > 2) { return true; } }); alert(someResult); var filterResult = num.filter(function(item) { if(item > 2) { return true; } }); alert(filterResult); var mapResult = num.map(function(item) { if(item > 2) { return true; } }); alert(mapResult); var forEachResult = num.forEach(function(item) { if(item > 2) { return true; } }); alert(forEachResult);
相關文章
JavaScript與ActionScript3兩者的同性與差異性
接觸JavaScript和ActionScript3也有近5年的時間了,它們都是應用比較廣泛的腳本語言.接下來通過本文給大家介紹JavaScript與ActionScript3兩者的同性與差異性,感興趣的朋友一起學習吧2016-09-09解決AjaxFileupload 上傳時會出現(xiàn)連接重置的問題
這篇文章主要介紹了解決AjaxFileupload 上傳時會出現(xiàn)連接重置的問題,需要的朋友可以參考下2017-07-07