Javascript數(shù)組實(shí)例教程

2022-06-12發(fā)布者:ylm大?。?/span> 下載:0

文件大小:

軟件介紹

在Javascript 1.0中構(gòu)造器只存在Date對象和用戶定義的對象。你可能期望有個數(shù)組構(gòu)造器,但是一直沒能實(shí)現(xiàn),直到JavaScript 1.1的出現(xiàn),你的期望成為了現(xiàn)實(shí)。我們可以如下來定義用戶對象:

function blankArray(n) {

for (var i=0; i < n; i++)

this[i] = null;

this.length = n;

}

blankArray函數(shù)創(chuàng)建了一個數(shù)組,這個數(shù)組中有n個空白項(xiàng)。下面再給出使用這個構(gòu)造器的例子:

var myArray = new blankArray(3);

myArray[0] = "hello";

myArray[1] = "world";

myArray[2] = "!";

如果你對其它編程語言(如C語言)有些經(jīng)驗(yàn)的話,你就會直到數(shù)組的索引是從0開始的而?此在上面的例子中數(shù)組索引是從0到2的,故這個數(shù)組的長度為3。

以下的代碼是更為高級的數(shù)組構(gòu)造器。它使用了arguments屬性來對數(shù)組賦值而不只是創(chuàng)建一個空數(shù)組元素,這個屬性對于所有的函數(shù)都是存在的。雖然沒有給定任何的參數(shù),傳遞的數(shù)值仍然可以通過arguments數(shù)組來進(jìn)行訪問。具體代碼如下:

function makeArray() {

for (var i=0; i < arguments.length; i++)

this[i] = arguments[i];

this.length = arguments.length;

}

而構(gòu)造器的調(diào)用可以是這樣的:

var myArray = new makeArray("hello", "world", "!");

在JavaScript 1.1中,創(chuàng)建數(shù)組構(gòu)造器結(jié)合了blankArray和makeArray的特定。如下的一個調(diào)用:

var myArray = new Array(3); // requires JS 1.1

這個調(diào)用創(chuàng)建了一個空白數(shù)組(其長度為3)作為上面示范的blankArray構(gòu)造器。而在Netscape中稱為dense array,因?yàn)槊恳粋€元素都有一個數(shù)值,可以如下來創(chuàng)建:

var myArray = new Array(value1, value2, value3); // JS 1.1
既然你對構(gòu)造器和對象屬性比較熟悉了,我們可以進(jìn)一步舉些例子。如果你是使用JavaScript 1.1或者更高版本,你可以使用數(shù)組構(gòu)造器。否則你使用makeArray對象更為合適些。 var workPeople = new Array(

new Person("Thomas", 25, "green"),

new Person("Richard", 35, "blue"),

new Person("Harold", 30, "chartreuse")

);

workPeople是一個擁有三個Person對象的數(shù)組。每一個Person都有name(名字)、age(年齡)、colour(膚色)以及birthYear(出生年份)屬性。

以下再給出一個實(shí)例來使用我們上面所學(xué)到的。這里還要提醒一下,Person代碼塊和workPeople數(shù)組必須包括到相同的SCRIPT標(biāo)簽中或者網(wǎng)頁的其它地方。

<SCRIPT language="JavaScript">

<!-- Hide from older browsers


function whoIsOldest(pArray) {

var pOldest = pArray[0]; // 數(shù)組中的第一個Person

for (var i=1; i < pArray.length; i++) // 對每個附加的Person循環(huán)

if (pArray[i].isOlder(pOldest)) // 如果它們比較老

pOldest = pArray[i]; // 將它們設(shè)置為最老

return pOldest;

}

var senior = whoIsOldest(workPeople);

document.write("The oldest person is " + senior.name + "<br>" + senior);


// Stop hiding -->

</SCRIPT>

上面例子的輸出為:

The oldest person is Richard

Richard was born in 1963

and is 35 years old.

從whoIsOldest函數(shù)返回的數(shù)值是一個Person對象,它帶有對象所有的屬性和方法。這是為什么可以引用名字屬性和變量PRintPerson()方法(稱為senior)的原因。

WhoIsOldest函數(shù)的另外一些特性為:

a.處理任何的People的數(shù)組。

b.處理任何對象類型的數(shù)組,這個數(shù)組有一個isOlder()方法。

如果不是使用JavaScript,換成其它類型的編程語言,你就不得不指定函數(shù)輸入是一個People的數(shù)組,而在JavaScript就不用了。這正是JavaScript的

發(fā)表評論(共0條評論)
請自覺遵守互聯(lián)網(wǎng)相關(guān)政策法規(guī),評論內(nèi)容只代表網(wǎng)友觀點(diǎn),發(fā)表審核后顯示!

版權(quán)聲明:

1 本站所有資源(含游戲)均是軟件作者、開發(fā)商投稿,任何涉及商業(yè)盈利目的均不得使用,否則產(chǎn)生的一切后果將由您自己承擔(dān)!

2 本站將不對任何資源負(fù)法律責(zé)任,所有資源請?jiān)谙螺d后24小時內(nèi)刪除。

3 若有關(guān)在線投稿、無法下載等問題,請與本站客服人員聯(lián)系。

4 如侵犯了您的版權(quán)、商標(biāo)等,請立刻聯(lián)系我們并具體說明情況后,本站將盡快處理刪除,聯(lián)系QQ:2499894784

返回頂部