javascript object array方法使用詳解
更新時(shí)間:2012年12月03日 15:45:24 作者:
在javascript開發(fā)中經(jīng)常會(huì)使用到array中方法,本文將對(duì)其一一詳細(xì)介紹,需要了解的朋友可以參考下
Array.prototype.push
push向數(shù)組尾部添加一項(xiàng)并更新length ,返回?cái)?shù)組長(zhǎng)度。
如果Object使用push會(huì)怎樣?
看下面代碼, obj好像數(shù)組一樣工作了。length會(huì)自動(dòng)更新。
var push = Array.prototype.push;
var obj = {};
push.call(obj, "hello"); // 返回值 1
// obj {"0":"hello", length:0}
push.call(obj, "world"); // 返回值 2
// obj {"0":"hello", "1":"world",length:2}
Array.prototype.length Array.prototype.splice
把length和splice 給Object
看下面代碼:obj這貨居然變成數(shù)組了?其實(shí)不然這可能是調(diào)試工具的一些輸出檢查問(wèn)題。
我們用 instanceof 測(cè)試 obj instanceof Array //false
var obj = { length:0, splice:Array.prototype.splice};console.log( obj ); // 打?。篬]
繼續(xù)看下面的代碼:
obj.push(0)//返回obj.length
1obj.push(1)//返回obj.length
2obj.splice(0, 1);//刪除第一項(xiàng) 返回刪除項(xiàng)
[0]obj.length // 1 splice刪除一項(xiàng)的時(shí)候同樣更新 length屬性
這樣obj的表現(xiàn)幾乎和array一樣了。不出意外slice,pop,shift,unshift什么的都可以正常工作在object中。
不過(guò)如果直接設(shè)置length,在數(shù)組中會(huì)刪除大于length的下表的項(xiàng), 但里的obj并不不會(huì)更新。
應(yīng)用在哪?
jQuery對(duì)象表現(xiàn)像一個(gè)array,其實(shí)他是一個(gè)對(duì)象。這種對(duì)象如何new出來(lái)呢?
實(shí)際jQuery把Array的方法借給Object,從而達(dá)到這個(gè)jQuery對(duì)象的效果,jQuery對(duì)象內(nèi)部也直接使用push等Array的方法。
看看jQuery的部分源碼 (注意加粗)
// Start with an empty selector
selector: "",
// The current version of jQuery being used
jquery: "1.7.1",
// The default length of a jQuery object is 0
length: 0,
......
// For internal use only.
// Behaves like an Array's method, not like a jQuery method.
push: push,
sort: [].sort,
splice: [].splice
如果你要把Object玩成Array,那么可能潛在的問(wèn)題length屬性不會(huì)和“數(shù)組”項(xiàng)總和對(duì)應(yīng)起來(lái)。
所以直接使用length設(shè)置長(zhǎng)度不會(huì)得到支持。
看下面jquery代碼,雖然length更新了,jquery的對(duì)象并沒(méi)更新。(當(dāng)然這并不是jquery的問(wèn)題)
var jq = $('div') //假設(shè)我們?cè)陧?yè)面獲取了40個(gè)
divjq.length // 40
jq.length = 0;jq// ? jq中仍然存放了40個(gè)dom對(duì)象 length屬性不會(huì)和“數(shù)組”項(xiàng)總和對(duì)應(yīng)起來(lái)。
Object使用array的方法還能正常工作,實(shí)在有些意想不到,可能實(shí)際應(yīng)用遠(yuǎn)不止這些。
push向數(shù)組尾部添加一項(xiàng)并更新length ,返回?cái)?shù)組長(zhǎng)度。
如果Object使用push會(huì)怎樣?
看下面代碼, obj好像數(shù)組一樣工作了。length會(huì)自動(dòng)更新。
復(fù)制代碼 代碼如下:
var push = Array.prototype.push;
var obj = {};
push.call(obj, "hello"); // 返回值 1
// obj {"0":"hello", length:0}
push.call(obj, "world"); // 返回值 2
// obj {"0":"hello", "1":"world",length:2}
Array.prototype.length Array.prototype.splice
把length和splice 給Object
看下面代碼:obj這貨居然變成數(shù)組了?其實(shí)不然這可能是調(diào)試工具的一些輸出檢查問(wèn)題。
我們用 instanceof 測(cè)試 obj instanceof Array //false
var obj = { length:0, splice:Array.prototype.splice};console.log( obj ); // 打?。篬]
繼續(xù)看下面的代碼:
obj.push(0)//返回obj.length
1obj.push(1)//返回obj.length
2obj.splice(0, 1);//刪除第一項(xiàng) 返回刪除項(xiàng)
[0]obj.length // 1 splice刪除一項(xiàng)的時(shí)候同樣更新 length屬性
這樣obj的表現(xiàn)幾乎和array一樣了。不出意外slice,pop,shift,unshift什么的都可以正常工作在object中。
不過(guò)如果直接設(shè)置length,在數(shù)組中會(huì)刪除大于length的下表的項(xiàng), 但里的obj并不不會(huì)更新。
應(yīng)用在哪?
jQuery對(duì)象表現(xiàn)像一個(gè)array,其實(shí)他是一個(gè)對(duì)象。這種對(duì)象如何new出來(lái)呢?
實(shí)際jQuery把Array的方法借給Object,從而達(dá)到這個(gè)jQuery對(duì)象的效果,jQuery對(duì)象內(nèi)部也直接使用push等Array的方法。
看看jQuery的部分源碼 (注意加粗)
復(fù)制代碼 代碼如下:
// Start with an empty selector
selector: "",
// The current version of jQuery being used
jquery: "1.7.1",
// The default length of a jQuery object is 0
length: 0,
......
// For internal use only.
// Behaves like an Array's method, not like a jQuery method.
push: push,
sort: [].sort,
splice: [].splice
如果你要把Object玩成Array,那么可能潛在的問(wèn)題length屬性不會(huì)和“數(shù)組”項(xiàng)總和對(duì)應(yīng)起來(lái)。
所以直接使用length設(shè)置長(zhǎng)度不會(huì)得到支持。
看下面jquery代碼,雖然length更新了,jquery的對(duì)象并沒(méi)更新。(當(dāng)然這并不是jquery的問(wèn)題)
var jq = $('div') //假設(shè)我們?cè)陧?yè)面獲取了40個(gè)
divjq.length // 40
jq.length = 0;jq// ? jq中仍然存放了40個(gè)dom對(duì)象 length屬性不會(huì)和“數(shù)組”項(xiàng)總和對(duì)應(yīng)起來(lái)。
Object使用array的方法還能正常工作,實(shí)在有些意想不到,可能實(shí)際應(yīng)用遠(yuǎn)不止這些。
您可能感興趣的文章:
- Javascript數(shù)組Array方法解讀
- JavaScript中數(shù)組Array方法詳解
- JavaScript ES5標(biāo)準(zhǔn)中新增的Array方法
- JS array 數(shù)組詳解
- JS Array.slice 截取數(shù)組的實(shí)現(xiàn)方法
- js刪除Array數(shù)組中指定元素的兩種方法
- JavaScript判斷變量是否為數(shù)組的方法(Array)
- JS中數(shù)組Array的用法示例介紹
- 以JSON形式將JS中Array對(duì)象數(shù)組傳至后臺(tái)的方法
- JavaScript中Array方法你該知道的正確打開方法
相關(guān)文章
javascript charAt() arr[i]數(shù)組實(shí)例代碼
實(shí)例區(qū)別一下charAt()和arr[i].toString()的使用方法2008-08-08
Javascript 實(shí)現(xiàn)TreeView CheckBox全選效果
Javascript 實(shí)現(xiàn)TreeView CheckBox 選中父節(jié)點(diǎn)時(shí)所有子節(jié)點(diǎn)全選,取消時(shí)全部取消2010-01-01
JavaScript優(yōu)化專題之Loading and Execution加載和運(yùn)行
這篇文章主要介紹了JavaScript優(yōu)化專題中Loading and Execution加載和運(yùn)行的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-01-01
BootStrap 下拉菜單點(diǎn)擊之后不會(huì)出現(xiàn)下拉菜單(下拉菜單不彈出)的解決方案
最近學(xué)到Bootstrap下拉菜單,學(xué)懂了教程內(nèi)容之后自己敲一個(gè)點(diǎn)擊按鈕底下彈出下拉菜單的小demo,寫完代碼發(fā)現(xiàn)運(yùn)行之后點(diǎn)擊按鈕沒(méi)反應(yīng),下拉菜單彈不出來(lái),下面給大家分享下解決方案2016-12-12
詳解javascript中原始數(shù)據(jù)類型Null和Undefined
這篇文章主要介紹了javascript中原始數(shù)據(jù)類型Null和Undefined的相關(guān)資料,需要的朋友可以參考下2015-12-12
JS在onclientclick里如何控制onclick的執(zhí)行
這篇文章主要介紹了JS在onclientclick里如何控制onclick的執(zhí)行的相關(guān)資料,需要的朋友可以參考下2016-05-05
從零開始用electron手?jǐn)]一個(gè)截屏工具的示例代碼
這篇文章主要介紹了從零開始用electron手?jǐn)]一個(gè)截屏工具的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-10-10

