国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

javascript中對象的定義、使用以及對象和原型鏈操作小結

2024-05-06 16:33:39
字體:
來源:轉載
供稿:網友

本文實例總結了javascript中對象的定義、使用以及對象和原型鏈操作。分享給大家供大家參考,具體如下:

1. 除了5種基本類型外,JS中剩下的就是對象

(1)對象的定義:

直接定義:

var test={x:1,y:1}

new方式創建:

var test=new Object({x:1})

Object.create方式:

var test=Object.create({x:1})

(2)對象上的賦值與取值

舉例:

var test={x:1,y:2}

方法一:可以通過test['x']取值

方法二:可以通過test.x取值

本質,將[]里面的值toString之后取到,比如我們這里有賦值語句比如:

test[{}]=3;

可以通過test[{z:1}]取到值3,若為5大基本類型,則要通過相同值取。

簡而言之,就是test內部的值會調用toString方法后存儲。

2.對象與原型鏈

(1)這里涉及到了JS中的繼承,JS的對象中除了null,其他都繼承于原型對象object.prototype,也就是說JS的大部分對象的原型鏈上的頂端都具有對象object.prototype.

JS是基于原型鏈集成的,并且對象上可以訪問到原型鏈上對象的屬性和方法。

舉例:

function test(){ this.x=x; this.y=y}var my=new test();test.prototype.z=3;alert(my.z); //輸出為3

test.prototype為my的直接父鏈原型,并且my也可以沿著原型鏈查找,直到object.prototype,因此可以實現object.prototype中的方法,比如

my.toString();//返回[object Object]

(2)原型鏈對于對象遍歷的影響

我們上述定義了一個對象my,如果對對象使用for in遍歷,那么會有

function test(){  this.x=1;  this.y=2;}var my=new test();test.prototype.z=3;console.log(my.__proto__);//會輸出test.prototypefor( p in my){ console.log(my[p])//會輸出1,2,3}

我們發現最后輸出了my[p]的值為1,2,3,發現遍歷my上的屬性時候,把my對象原型鏈上的屬性也遍歷出來了。

補充:并且這種遍歷是無序的。

(3)特殊賦值

針對上述例子,如果我們對my對象進行賦值,

my.z=4;alert(my.z);//這里得到的值為4

我們發現,如果對象上的屬性和對象原型上的對象沖突,優先對于對象上屬性進行賦值。

(4)在對象的原型鏈上,所有對象都繼承與object.prototype,除了null,我們可以用以下鏈式來反應:

my(或者其他對象)—>test.prototype–>……..–>object.prototype——>null

希望本文所述對大家JavaScript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 萨迦县| 兴仁县| 宜昌市| 通河县| 旬阳县| 淮北市| 天门市| 内乡县| 沁水县| 涞源县| 汝城县| 广南县| 宜城市| 阿尔山市| 铜鼓县| 宕昌县| 远安县| 阜阳市| 梓潼县| 昔阳县| 汝阳县| 河南省| 荔波县| 德保县| 余庆县| 石河子市| 高尔夫| 镇巴县| 福州市| 宁德市| 玛曲县| 称多县| 桐庐县| 广宗县| 海兴县| 科尔| 乳山市| 石台县| 竹山县| 交城县| 晋中市|