真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

JS原型與原型鏈的示例分析

這篇文章主要介紹JS原型與原型鏈的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

創(chuàng)新互聯(lián)建站專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、睢縣網(wǎng)絡(luò)推廣、小程序定制開發(fā)、睢縣網(wǎng)絡(luò)營(yíng)銷、睢縣企業(yè)策劃、睢縣品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);創(chuàng)新互聯(lián)建站為所有大學(xué)生創(chuàng)業(yè)者提供睢縣建站搭建服務(wù),24小時(shí)服務(wù)熱線:18982081108,官方網(wǎng)址:www.cdcxhl.com

一、普通對(duì)象和函數(shù)對(duì)象的區(qū)別

在Javascript的世界里,全都是對(duì)象,而對(duì)象之間也是存在區(qū)別,我們首先區(qū)分一下普通對(duì)象和函數(shù)對(duì)象,如下代碼:

function f1(){};
var f2 = function(){};
var f3 = new function(){};

var o1 = {};
var o2 = new Object();
var o3 = new f1();

console.log(typeof Object); //function
console.log(typeof Function);//function
console.log(typeof f1) //function
console.log(typeof f2) // function
console.log(typeof f3) //function
console.log(typeof o1) //object
console.log(typeof o2) //object
console.log(typeof o3)// object

在上面的代碼中可以看出,f1、f2和f3都是函數(shù)對(duì)象,而o1,o2和o3都是object對(duì)象,也就是普通對(duì)象,函數(shù)對(duì)象本質(zhì)就是由new function()構(gòu)造而來,其他的都是普通對(duì)象;函數(shù)對(duì)象和普通對(duì)象理解之后,后文會(huì)說明兩者的區(qū)別。

二、原型

在JavaScript中,原型也是一個(gè)對(duì)象,原型的作用,則是實(shí)現(xiàn)對(duì)象的繼承。

在js的所有函數(shù)對(duì)象中,都存在一個(gè)屬性prototype,該屬性對(duì)應(yīng)當(dāng)前對(duì)象的原型。

而所有的JavaScript對(duì)象,都存在一個(gè)_proto_屬性(由于_proto_是個(gè)非標(biāo)準(zhǔn)屬性,因此只有ff和chrome兩個(gè)瀏覽器支持,標(biāo)準(zhǔn)方法是Object.getPrototypeOf()),_proto_屬性指向?qū)嵗龑?duì)象的構(gòu)造函數(shù)的原型,理解起來就如下:

var p = new Person(); 
console.log(p._proto === Person.prototype)//true

從上面代碼可以看出,p是實(shí)例對(duì)象,Person是p的構(gòu)造函數(shù),可以看出來p的_proto_屬性指向構(gòu)造函數(shù)Person的原型。

下面用代碼來解釋一下js是如何通過原型進(jìn)行繼承的:

var parent = function(name){
 this.name = name;
}
parent.prototype.getName = function(){
 return this.name;
}
var son = new parent("huahua");

console.log(son.getName());//'huahua'

顯然,son繼承了parent的原型中的函數(shù)屬性getName。

三、原型鏈

除開Object的prototype的原型是null以外,所有的對(duì)象和原型都有自己的原型,對(duì)象的原型指向原型對(duì)象。

在層級(jí)多的關(guān)系中,多個(gè)原型層層相連則構(gòu)成了原型鏈。

在查找一個(gè)對(duì)象的屬性時(shí),倘若在當(dāng)前對(duì)象找不到該屬性,則會(huì)沿著原型鏈一直往上查找,知道找到為止,如果到了原型鏈頂端,還沒找到,則返回undefined。

JS原型與原型鏈的示例分析

四、constructor

constructor是構(gòu)造函數(shù)創(chuàng)建的實(shí)例的屬性,該屬性的作用是指向創(chuàng)建當(dāng)前對(duì)象的構(gòu)造函數(shù)。

例如,son.constructor == parent;//true

以上是“JS原型與原型鏈的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


本文題目:JS原型與原型鏈的示例分析
標(biāo)題來源:http://weahome.cn/article/psiopi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部