麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 語言 > JavaScript > 正文

淺談Javascript數組的使用

2024-05-06 16:23:59
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了淺談Javascript數組的使用的相關資料,包括數組的大小,數組的遍歷以及數組的一些方法,非常細致,需要的朋友可以參考下

上一篇說了數組的索引,這一篇說下數組的使用。

數組的大小

js的數組可以動態調整大小,更確切點說,它沒有數組越界的概念,a[a.length]沒什么問題。比如聲明一個數組a = [1, 3, 5],現在的數組大小是3,最后一個元素的索引是2,但是你依然可以使用a[3],訪問a[3]返回的是undefined,給a[3]賦值:a[3] = 7,是給數組a添加了一個元素,現在數組a的長度是4了。你可以試試把下面這段代碼放到瀏覽器里運行下:


var a = [];
for(int i = 0; i <= a.length; i++)
{
a[a.length] = i;
}
在我的電腦上,火狐會立馬崩掉,chrome這一個標簽cpu占用99%(使用chrome的任務管理器查看的)。

js的length的值會隨著數組元素的改變而改變,當然你也可以手動設置數組的 length 屬性,設置更大的length不會給數組分配更多的空間,但是設置更小的length則會導致所有下標大于等于新length的屬性被刪除。

另外有一點就是,數組的length值是怎么來的,有的資料說是最大一個數字索引值加一,應該是對的,不過如果把空槽也算數的話,length值就是數組的元素數。上張圖解釋下:



從圖里可以看到,有個數組a,a[0]和a[10]都已賦值,這時候a的length是11,中間有9個empty slot(姑且就翻譯為空槽好了)。那這九個空槽算不算數呢,我覺得應該算,這樣就能合理的解釋length值了。那這些空槽的值是什么呢?undefined!所以呢,如果在chrome里,使用foreach遍歷(forin),那么這些空槽正好都能跳過,而使用for遍歷,則會打印出undefined。至于在firefox里,表現不太一樣,自己試吧。

數組的遍歷

昨天在看微博上轉的js教程的時候,里面說在遍歷數組的時候,判斷語句i

關于數組的foreach遍歷,js的方式相對于java/c#等語言是很奇怪的:




for(var name in ['huey', 'dewey', 'louie']) {
console.log(name);
}
/*
打印結果:
0
1
2
*/
可以看到,打印的結果不是數組的元素,而是數字索引值(感覺這好像也可以說明,js的數組也是用hash的方式存儲的),不管怎樣,這一點要注意。(至于為什么這樣,我覺得數組元素都是數組的屬性,這個遍歷是遍歷的length值,從0到length。而不是逐個輸出數組的元素,因為元素是屬性,數組又不只數字索引這一種屬性,那么為什么這樣遍歷的時候只輸出它們呢,而不是length,push,join等方法?公平起見,只好輸出數組的數字索引了。當然,這只是我自己的看法,具體怎么樣我沒研究。)

數組的一些方法

數組有push和pop方法,這樣數組就像堆棧一樣了。對數組使用delete,可以將數組中某個元素移除,但是那樣會在數組中留下一個空洞(也就是說delete也可以刪除數組中的元素,但是只是刪除該位置的值,不改變數組大小,原位置類型是undefined),這是因為排在被刪除元素之后的元素保留著它們最初的屬性,所以應該使用splice對進行過delete操作的數組進行瘦身,它會將被刪除的屬性移除,但這樣效率并不是很高。數組中還有map、reduce、filter等方法,這里就不多說了(跟python中的list挺像的)。

補充

最后補充一點,我前面說過,js中的數組就是對象(廢話,本來就是對象),那么是不是說,數組和對象可以互相互替換著用呢?答案是可以的。不過為了明確,還是分開用比較好,下面說下什么時候該用數組,什么時候該用對象(參考《javascript語言精粹》):

當屬性名是小而連續的整數時,應該使用數組,否則,使用對象。

另外由于js中對數組和對象使用 typeof 的結果都是 Object,因此判斷一個對象是否為數組的方法:




var is_array = function(value) {
return Object.prototype.toString.apply(value) === '[object Array]';
};
番外

覺得閉包被神化了,可能語言層面上的實現有技術,但是在應用層面我覺得就應該那樣啊,使用的時候都感覺不到那是在用閉包。但是這個閉包卻幾乎成了面試前端必問的概念了。

以上所述就是本文的全部內容了,希望大家能夠喜歡。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 91看片淫黄大片欧美看国产片 | 爽爽淫人网 | 日韩精品中文字幕一区 | 久久国产精品久久久久久电车 | 国产精品视频海角社区88 | 国内精品久久久久久2021浪潮 | 国产资源在线观看 | 精品国产观看 | 国产欧美日韩在线不卡第一页 | 精品麻豆cm视频在线看 | 国产一精品久久99无吗一高潮 | h视频在线观看免费 | 久久久久久久91 | 在线中文字幕亚洲 | 久久精品一级 | 羞羞视频一区 | 理论片中文字幕 | 毛片118极品美女写真 | 久久久久亚洲国产精品 | 最新中文字幕在线视频 | 成人毛片免费播放 | 91在线播放国产 | 人人舔人人舔 | 中文字幕综合在线观看 | 欧美毛片 | 国产精品免费观在线 | 久久成年人视频 | 91avsese| 毛片视频免费观看 | 特片网久久| 亚洲精品一区国产精品丝瓜 | 老司机免费福利午夜入口ae58 | 多男操一女视频 | 国产福利视频 | 一本一本久久a久久精品综合小说 | 亚洲午夜久久久精品一区二区三区 | 中国女警察一级毛片视频 | 亚洲国产高清视频 | 国产超碰人人做人人爱 | 神马久久精品综合 | 日韩高清影视 |