欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解JavaScript對象和數(shù)組

 更新時間:2015年12月03日 14:52:35   作者:丿木呈廣予口貝  
這篇文章主要介紹了JavaScript對象和數(shù)組,需要的朋友可以參考下

許多高級編程語言都是面向?qū)ο蟮?,比如C++、C#和Java等高級程序設(shè)計語言,那么一種面向?qū)ο笳Z言有哪些基本要求呢?下面我們就通宿地說一下面向?qū)ο蟮囊恍┲R。
一種面向?qū)ο笳Z言需要向開發(fā)者提供四種基本能力:

  •        (1)封裝:把相關(guān)的信息(無論數(shù)據(jù)或方法)存儲在對象中的能力
  •        (2)聚集:把一個對象存儲在另一個對象內(nèi)的能力
  •        (3)繼承:由另一個類(或多個類)得來類的屬性和方法的能力
  •        (4)多態(tài):編寫能以多種方法運(yùn)行的函數(shù)或方法的能力

       由于ECMAScript支持這些要求,因此可被是看做面向?qū)ο蟮?。在ECMAScript中,不能訪問對象的物理表示,只能訪問對象的引用。每次創(chuàng)建對象,存儲在變量中的都是該對象的引用,而不是對象本身。因此JavaScript是基于面向?qū)ο蟮囊环N弱類型的網(wǎng)頁腳本語言。
 一、Object類型
       Object類型是包含屬性(也可以叫字段)和方法(也可以叫函數(shù))。因此在創(chuàng)建Object類型的時候一定是要說明的要點(diǎn)。 一般創(chuàng)建Object類型數(shù)的方法有兩種:
 (1)使用new運(yùn)算符

var box=new Object(); 
box.name="張三";//創(chuàng)建屬性以及初始化 
box.age=23; 
box.run=running();//創(chuàng)建方法 
function running(){ 
   return "我是中國人!"; 
} 
document.write(typeof box+"<br/>"); 
document.write(box.name+"<br/>"); 
document.write(box.age+"<br/>"); 
document.write(box.run); 

輸出:object
          張三
          23
          我是中國人!
(2)字面量表示法

var box={ 
 name:"張三", 
 age:23, 
 run:function(){  
   return "我是中國人!"; 
 } 
}; 
document.write(typeof box+"<br/>"); 
document.write(box.name+"<br/>"); 
document.write(box.age+"<br/>"); 
document.write(box.run()); 

輸出:同上
(3)綜合使用
       我們在傳遞多個參數(shù)的情況下,需要我們按順序依次輸入,為了解決這個繁瑣的過程,我們可以將多個參數(shù)封裝
到一個Object類型中,使用Object類型作為參數(shù),對于不存在或多出的參數(shù)我們也可以進(jìn)行判斷,這樣方便了調(diào)用函
數(shù)及傳遞參數(shù)。

function box(obj){ 
  if(obj.name!=undefined)document.write(obj.name+"<br/>"); 
  if(obj.age!=undefined)document.write(obj.age+"<br/>"); 
  if(obj.love!=undefined)document.write(obj.love+"<br/>"); 
} 
var obj={ 
  name:"張三", 
  age:23 
}; 
box(obj); 

輸出:張三
          23
二、Array類型
        ECMAScript中的數(shù)組和其他的語言有著很大的差別,JS中的數(shù)組中的元素可以是任何數(shù)據(jù)類型,數(shù)組的大小也
是可以調(diào)整的。從側(cè)面反映出了JS是一種弱類型語言。創(chuàng)建Array類型數(shù)的方法有兩種:
(1)使用new運(yùn)算符(new可以省略)

var box=new Array(1,2,3,4); 
document.write(typrof box+"<br/>");//Array屬于Object類型 
document.write(box);//輸出1,2,3,4 

索引下標(biāo)從0開始

var box=new Array(1,2,3,4); 
document.write(box[0]+box[1]+box[2]+box[3]);//輸出1,2,3,4 

創(chuàng)建一個包含十個元素的數(shù)組

var box=new Array(10);//創(chuàng)建數(shù)組默認(rèn)必須是數(shù)字,必須是一位數(shù)字 
box[3]=4;//初始化數(shù)組中的元素 
box[5]=6; 
document.write(box);//輸出,,,4,,6,,,, 

(2)使用字面量創(chuàng)建數(shù)組

var box=[1,2,3,4]; 
document.write(typrof box+"<br/>");//輸出Object 
document.write(box.length+"<br/>");//輸出數(shù)組的長度為4 
document.write(box);//輸出1,2,3,4 

創(chuàng)建一個復(fù)雜的數(shù)組(可以是各種各樣的類型)

var box=[ 
  { 
   name:"張三", 
   age:23 
  },//Object類型 
  [1,2,3,4],//Array類型 
  "JS",//String類型 
  25+25,//Number類型 
  new Array(1,2,3)//Array類型 
]; 
document.write(typeof box+"<br/>"); 
document.write(box[0].name+"<br/>"); 
document.write(box[3]); 

頁面輸出的結(jié)果為:

三、對象中的方法
(1)轉(zhuǎn)換方法
       對象或數(shù)組都具有toLocaleString(),toString()和valueOf()方法。其中toString()和valueOf()無論重寫了誰,都會返
回相同的值。數(shù)組會將每個值進(jìn)行字符串形式的拼接,以逗號隔開。

var box=[1,2,3,4]; 
document.write(box+"<br/>");//輸出1,2,3,4 
document.write(box.toString()+"<br/>");//輸出1,2,3,4 
document.write(box.valueOf()+"<br/>");//輸出1,2,3,4 
document.write(box.toLocaleString());//輸出1,2,3,4 

       默認(rèn)的情況下,數(shù)組字符串都會以逗號隔開。如果使用join()方法可以使用不同的分割符來構(gòu)建這個字符串

var box=[1,2,3,4]; 
document.write(box+"<br/>"); 
document.write(typeof box+"<br/>"); 
document.write(box.join("-")+"<br/>"); 
document.write(typeof box.join("-")); 

頁面輸出的結(jié)果為:

(2)棧方法
       ECMAScript數(shù)組提供了一種讓數(shù)組的行為類似于其他數(shù)據(jù)結(jié)構(gòu)的方法。也就是說,可以讓數(shù)組像棧一樣,可以限
制插入和刪除想的數(shù)據(jù)結(jié)構(gòu)。棧是一種后進(jìn)先出的數(shù)據(jù)結(jié)構(gòu),也就是最新添加的元素最早被移除。而棧元素的插入和
移除,只發(fā)生在棧的頂部。ECMAScript為數(shù)組專門提供了push()和pop()方法。
       棧操作數(shù)組元素的圖片:

        push()方法可以接受任意數(shù)量的參數(shù),把它們逐個添加到數(shù)組的末尾,并返回修改數(shù)組的長度。而pop()方法則從
數(shù)組末尾移除最后一個元素,減小數(shù)組的length值,然后返回移除的元素。

var box=[1,2,3,4]; 
document.write(box+"<br/>"); 
box.push(5,6);//在數(shù)組末尾添加元素 
document.write(box+"<br/>"); 
document.write(box.push(7,8)+"<br/>");//在數(shù)組末尾添加元素,并返回添加元素后數(shù)組的長度 
document.write(box+"<br/>"); 
box.pop();//移除數(shù)組末尾的元素 
document.write(box+"<br/>"); 
document.write(box.pop()+"<br/>");//移除數(shù)組末尾的元素,并返回移除的元素 
document.write(box); 

        輸出:

 (3)隊(duì)列方法
       棧方法是后進(jìn)先出,隊(duì)列方法是先進(jìn)先出。隊(duì)列在數(shù)組的末端添加元素,從數(shù)組的前端移除元素。通過push()向
數(shù)組末端添加一個元素,然后通過shift()方法從數(shù)組的前端移除一個元素。
       隊(duì)列操作數(shù)組元素的圖片

var box=[1,2,3,4]; 
document.write(box+"<br/>"); 
box.push(5,6);//在數(shù)組末尾添加元素 
document.write(box+"<br/>"); 
document.write(box.push(7,8)+"<br/>");//在數(shù)組末尾添加元素,并返回添加元素后數(shù)組的長度 
document.write(box+"<br/>"); 
box.shift();//移除數(shù)組前端的一個元素 
document.write(box+"<br/>"); 
document.write(box.shift()+"<br/>");//移除數(shù)組前端的一個元素,并返回移除的元素 
document.write(box); 

       輸出:

       ECMAScript還為數(shù)組提供了一個unshift()方法,它和shift()方法的功能完全相反。unshift()方法為數(shù)組的前端添加
一個元素。

var box=[1,2,3,4]; 
document.write(box+"<br/>"); 
box.unshift(0);//在數(shù)組的前端添加一個元素 
document.write(box+"<br/>"); 
document.write(box.unshift(-1)+"<br/>");//在數(shù)組的前端添加一個元素,并返回添加元素會數(shù)組的長度 
document.write(box+"<br/>"); 
box.pop();//在數(shù)組末尾移除元素 
document.write(box+"<br/>"); 
document.write(box.pop()+"<br/>");//在數(shù)組末尾移除元素,并返回移除元素后數(shù)組的長度 
document.write(box); 

       輸出:

(4)重排序方法
數(shù)組中已經(jīng)存在兩個直接用來排序的方法:reverse()和sort()。
reverse():逆向排序

var box=[1,2,3,4,5]; 
box.reverse(); 
document.write(box+"<br/>");//輸出54321 
document.write(box.reverse());//再次進(jìn)行逆序,輸出12345 

sort():從小到大排序

var box=[3,2,6,4,1,5]; 
box.sort(); 
document.write(box+"<br/>");//輸出1,2,3,4,5,6 
document.write(box.sort());//再次從小到大進(jìn)行排序 

如果我們實(shí)驗(yàn)次數(shù)多的話可能回遇到這樣的問題,

var box=[0,15,10,1,5]; 
box.sort(); 
document.write(box);//輸出0,1,10,15,5 

 我們從結(jié)果可以看出,這違背了我們想要的結(jié)果,解決方法:

function compare(value1,value2){ 
  if(value1<value2){ 
   return -1; 
  } 
  else if(value1>value2){ 
   return 1; 
  } 
  else{ 
   return 0;  
  }  
} 
var box=[0,15,10,1,5]; 
box.sort(compare); 
document.write(box);//輸出0,1,5,10,15 

 (5)操作方法
JS為操作已經(jīng)包含在數(shù)組中的元素提供了許多的方法。concat()方法可以基于當(dāng)前數(shù)組創(chuàng)建一個新數(shù)組。slice()方
法可以基于當(dāng)前數(shù)組獲取指定區(qū)域元素并創(chuàng)建一個新數(shù)組。splice()方法主要用途是向數(shù)組的中部插入元素。
 a

var box=[1,2,3,4,5]; 
var box1=box.concat(6);//創(chuàng)建新數(shù)組,并添加新元素 
document.write(box1+"<br/>");//輸出1,2,3,4,5,6, 
document.write(box);//原數(shù)組不變化 

b

var box=[1,2,3,4,5]; 
var box1=box.slice(2);//取出索引為2以后的元素組成新的數(shù)組 
document.write(box1+"<br/>");//輸出3,4,5 
document.write(box);//原數(shù)組不變化 

c

var box=[1,2,3,4,5]; 
var box1=box.slice(2,3);//取出索引為2到3之間的元素組成新的數(shù)組 
document.write(box1+"<br/>");//輸出3 
document.write(box);//原數(shù)組不變化 

splice中的刪除功能

var box=[1,2,3,4,5]; 
var box1=box.splice(0,2);//截取索引為0開始的兩個元素組成新的數(shù)組 
document.write(box1+"<br/>");//返回截取的元素1,2 
document.write(box);//當(dāng)前數(shù)組被截取的元素被刪除,輸出3,4,5 

splice中的插入功能

var box=[1,2,3,4,5]; 
var box1=box.splice(4,0,6);//索引為4的位置插入了一個元素 
document.write(box1+"<br/>");//返回新的數(shù)組為空,并沒有截取元素 
document.write(box);//當(dāng)前數(shù)組索引為4的位置插入一個元素1,2,3,4,6,5 

splice中的替換功

var box=[1,2,3,4,5]; 
var box1=box.splice(4,1,6);//索引為4的元素被替換,替換下來的元素組成新數(shù)組 
document.write(box1+"<br/>");//返回新的數(shù)組5 
document.write(box);//被替換后的原數(shù)組1,2,3,4,6 

以上就是關(guān)于JavaScript對象和數(shù)組的詳細(xì)介紹,希望對大家的學(xué)習(xí)有所幫助。

相關(guān)文章

  • window.onload 加載完畢的問題及解決方案(上)

    window.onload 加載完畢的問題及解決方案(上)

    我們經(jīng)常使用 window.onload 來處理頁面,當(dāng)頁面加載完成做一些事情。但這個 window.onload 是頁面全部加載完成,甚至包括圖片,而我們實(shí)際上經(jīng)常需要的是文檔 DOM 加載完畢!
    2009-07-07
  • 分享10個常見的JavaScript前端手寫功能

    分享10個常見的JavaScript前端手寫功能

    這篇文章主要分享10個常見的前端手寫功能,防抖、節(jié)流、深拷貝、異步控制并發(fā)數(shù)、繼承等功能技巧,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-02-02
  • JS 自定義帶默認(rèn)值的函數(shù)

    JS 自定義帶默認(rèn)值的函數(shù)

    今天與同事一起看了一個javscript定義函數(shù)問題,如何在定義一個函數(shù)里給參數(shù)一個默認(rèn)值.
    2011-07-07
  • ES6中Promise的使用方法實(shí)例總結(jié)

    ES6中Promise的使用方法實(shí)例總結(jié)

    這篇文章主要介紹了ES6中Promise的使用方法,結(jié)合實(shí)例形式總結(jié)分析了Promise對象中的各種常用方法及基本使用技巧,需要的朋友可以參考下
    2020-02-02
  • addEventListener()和removeEventListener()追加事件和刪除追加事件

    addEventListener()和removeEventListener()追加事件和刪除追加事件

    這篇文章主要給大家介紹了關(guān)于addEventListener()和removeEventListener()追加事件和刪除追加事件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • layui表格內(nèi)放置圖片,并點(diǎn)擊放大的實(shí)例

    layui表格內(nèi)放置圖片,并點(diǎn)擊放大的實(shí)例

    今天小編就為大家分享一篇layui表格內(nèi)放置圖片,并點(diǎn)擊放大的實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 微信小程序?qū)崿F(xiàn)搜索框功能

    微信小程序?qū)崿F(xiàn)搜索框功能

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)搜索框功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • JS設(shè)計模式之命令模式的用法詳解

    JS設(shè)計模式之命令模式的用法詳解

    JavaScript中的命令模式是一種設(shè)計模式,它提供了一種將命令封裝為對象的方式,從而允許我們將請求與實(shí)際執(zhí)行該請求的操作對象解耦,這種模式可以在不同的場景中使用,例如實(shí)現(xiàn)撤銷/重做操作、隊(duì)列任務(wù)等,本文我們將講解命令設(shè)計模式在JS中的使用
    2023-08-08
  • 微信小程序視頻彈幕發(fā)送功能的實(shí)現(xiàn)

    微信小程序視頻彈幕發(fā)送功能的實(shí)現(xiàn)

    這篇文章主要介紹了微信小程序視頻彈幕發(fā)送功能的實(shí)現(xiàn),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • js實(shí)現(xiàn)瀑布流的一種簡單方法實(shí)例分享

    js實(shí)現(xiàn)瀑布流的一種簡單方法實(shí)例分享

    現(xiàn)在說瀑布流式布局似乎有點(diǎn)晚了,但是每一項(xiàng)技術(shù)都是向著“精”和“簡”的方向在不斷發(fā)展,在發(fā)展到極致之前,需要一個相當(dāng)漫長的過程,因此,從這個角度來說,當(dāng)瀑布流被應(yīng)用得越來越多的時候,反而更應(yīng)該討論它,討論如何將它改善
    2013-11-11

最新評論