當(dāng)前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
09_JS原型对象
原型對象
在構(gòu)造函數(shù)中,同一類相同的方法可以直接寫在構(gòu)造函數(shù)里,但這樣每實(shí)例化一個(gè)對象都會(huì)產(chǎn)生一個(gè)新的該方法,但其實(shí)這個(gè)方法都是一樣的,這樣會(huì)浪費(fèi)大量空間,另外,可以將相同的方法寫在構(gòu)造函數(shù)外,這樣雖然解決了空間浪費(fèi)問題,但在全局作用域設(shè)置變量污染了命名空間,也不安全。這時(shí)可以將相同的屬性和方法放在原型對象中。
- 在JS中,我們所創(chuàng)建的每一個(gè)函數(shù),解析器都會(huì)為他添加一個(gè)prototype屬性,這個(gè)屬性對應(yīng)一個(gè)對象,就是原型對象
- 對于普通函數(shù)來說,prototype屬性沒有任何作用,只有當(dāng)函數(shù)以構(gòu)造函數(shù)的形式調(diào)用時(shí),他所創(chuàng)建的對象都會(huì)有一個(gè)隱藏屬性指向原型對象,可以使用__proto__訪問
[外鏈圖片轉(zhuǎn)存失敗(img-T8P2zSX1-1562224188995)(image/yuanxing.jpg)]
當(dāng)我們訪問一個(gè)對象的屬性或方法時(shí),會(huì)現(xiàn)在自身找,找不到就去原型中找,找不到就去原型的原型中找,直到找到Object,Object是所有對象的原型
function Car(){this.type = "car";this.print = print; }Car.prototype.print = function(){console.log(this.name +" : " + this.parse); }- 可以使用hasownproperty()檢查自身是否有某個(gè)屬性
總結(jié)
- 上一篇: 关于Eclipse配置Tomcat8的问
- 下一篇: php++redius,【答疑】请问ed