小編給大家分享一下JavaScript設(shè)計(jì)模式之原型模式的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)成立于2013年,公司以成都網(wǎng)站建設(shè)、成都做網(wǎng)站、系統(tǒng)開(kāi)發(fā)、網(wǎng)絡(luò)推廣、文化傳媒、企業(yè)宣傳、平面廣告設(shè)計(jì)等為主要業(yè)務(wù),適用行業(yè)近百種。服務(wù)企業(yè)客戶超過(guò)千家,涉及國(guó)內(nèi)多個(gè)省份客戶。擁有多年網(wǎng)站建設(shè)開(kāi)發(fā)經(jīng)驗(yàn)。為企業(yè)提供專業(yè)的網(wǎng)站建設(shè)、創(chuàng)意設(shè)計(jì)、宣傳推廣等服務(wù)。 通過(guò)專業(yè)的設(shè)計(jì)、獨(dú)特的風(fēng)格,為不同客戶提供各種風(fēng)格的特色服務(wù)。
1、js屬于一種解釋性腳本語(yǔ)言;2、在絕大多數(shù)瀏覽器的支持下,js可以在多種平臺(tái)下運(yùn)行,擁有著跨平臺(tái)特性;3、js屬于一種弱類型腳本語(yǔ)言,對(duì)使用的數(shù)據(jù)類型未做出嚴(yán)格的要求,能夠進(jìn)行類型轉(zhuǎn)換,簡(jiǎn)單又容易上手;4、js語(yǔ)言安全性高,只能通過(guò)瀏覽器實(shí)現(xiàn)信息瀏覽或動(dòng)態(tài)交互,從而有效地防止數(shù)據(jù)的丟失;5、基于對(duì)象的腳本語(yǔ)言,js不僅可以創(chuàng)建對(duì)象,也能使用現(xiàn)有的對(duì)象。
具體如下:
從設(shè)計(jì)模式的角度講,原型模式是用于創(chuàng)建對(duì)象的一種模式,若需要?jiǎng)?chuàng)建一個(gè)對(duì)象,一種方法是先指定其類型,然后通過(guò)類來(lái)創(chuàng)建這個(gè)對(duì)象,另一種方法是通過(guò)原型來(lái)創(chuàng)建,不必關(guān)心對(duì)象的具體類型,而是找到一個(gè)對(duì)象,然后通過(guò)克隆來(lái)創(chuàng)建一個(gè)一模一樣的對(duì)象。
ES5提供了Object.create(obj)
方法來(lái)克隆對(duì)象,在不支持Object.create(obj)
方法的瀏覽器中,可以使用以下代碼:
Object.create = Object.create || function(obj) { function Func() {}; Func.prototype = obj; return new Func(); }
一、JavaScript中的原型繼承:
1. 大部分的數(shù)據(jù)都是對(duì)象;
JavaScript有兩種類型機(jī)制:基本類型和對(duì)象類型?;绢愋桶?code>undefined、number
、boolean
、string
、function
、object
。
JavaScript設(shè)計(jì)者的本意在于,除了undefined,一切都應(yīng)該是對(duì)象,為了實(shí)現(xiàn)這一目標(biāo),number、boolean、string這幾種基本數(shù)據(jù)類型通過(guò)對(duì)應(yīng)的包裝類Number、Boolean、String來(lái)變成對(duì)象類型數(shù)據(jù)。
JavaScript中的根對(duì)象是Object.prototype
對(duì)象,Object.prototype
對(duì)象是一個(gè)空的對(duì)象。JavaScript的每個(gè)對(duì)象,實(shí)際上都是從Object.prototype
對(duì)象克隆而來(lái)的,Object.prototype
對(duì)象就是它們的原型。
ES5提供了getPrototypeOf
來(lái)查看對(duì)象的原型,Object.getPrototypeOf(任何對(duì)象) == Object.prototype
都會(huì)返回true。
2. 要得到一個(gè)對(duì)象,不是通過(guò)實(shí)例化類,而是找到一個(gè)對(duì)象作為原型并克隆它;
JavaScript沒(méi)有類的概念,new運(yùn)算符后面的不是類,而是構(gòu)造器。當(dāng)使用new運(yùn)算符來(lái)創(chuàng)建對(duì)象時(shí),實(shí)際上也是先克隆Object.prototype
對(duì)象,再進(jìn)行一些額外操作的過(guò)程。
3. 對(duì)象會(huì)記住它的原型;
其實(shí)不能說(shuō)對(duì)象有原型,而只能說(shuō)對(duì)象的構(gòu)造器有原型。JavaScript給對(duì)象提供了一個(gè)名為__proto__
屬性,默認(rèn)指向它的構(gòu)造器的原型,__proto__
屬性是對(duì)象與構(gòu)造器的原型聯(lián)系起來(lái)的紐帶,如:person.__proto__ == Person.prototype
。
4. 若對(duì)象無(wú)法響應(yīng)某個(gè)請(qǐng)求,它會(huì)把該請(qǐng)求委托給它自己的原型。
這是原型繼承的精髓,當(dāng)一個(gè)對(duì)象無(wú)法響應(yīng)某個(gè)請(qǐng)求時(shí),會(huì)順著原型鏈把請(qǐng)求傳遞下去,直到遇到一個(gè)可以處理該請(qǐng)求的對(duì)象為止。但是,原型鏈并不是無(wú)限長(zhǎng)的,只會(huì)查找到Object.prototype
對(duì)象為止,由于Object.prototype
的原型是null
,因此請(qǐng)求無(wú)法找到可以處理的對(duì)象,返回undefined
。
二、原型繼承的未來(lái)
使用Object.create來(lái)實(shí)現(xiàn)原型繼承似乎更能體現(xiàn)原型模式的精髓,但是,通過(guò)Object.create
創(chuàng)建對(duì)象的效率并不高,通常要比通過(guò)構(gòu)造函數(shù)創(chuàng)建對(duì)象慢。
ES6帶來(lái)了新的Class語(yǔ)法,這讓JavaScript看起來(lái)像是一門基于類的語(yǔ)言,但背后仍然是通過(guò)原型機(jī)制來(lái)創(chuàng)建對(duì)象。
class Person { constuctor(name) { this.name = name; } getName() { return this.name; } } class Student extends Person { constuctor(name) { super(name); } sayHello() { alert(“Hello”); } } var student = new Student(“Alice”); student.sayHello();
以上是“JavaScript設(shè)計(jì)模式之原型模式的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!