亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript中工廠函數(shù)與構(gòu)造函數(shù)示例詳解

 更新時間:2019年05月06日 11:48:24   作者:前端小智  
這篇文章主要給大家介紹了關(guān)于JavaScript中工廠函數(shù)與構(gòu)造函數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

前言

當(dāng)談到JavaScript語言與其他編程語言相比時,你可能會聽到一些令人困惑東西,其中之一是工廠函數(shù)和構(gòu)造函數(shù)。

工廠函數(shù)

所謂工廠函數(shù),就是指這些內(nèi)建函數(shù)都是類對象,當(dāng)你調(diào)用他們時,實(shí)際上是創(chuàng)建了一個類實(shí)例”。意思就是當(dāng)我調(diào)用這個函數(shù),實(shí)際上是先利用類創(chuàng)建了一個對象,然后返回這個對象。由于 Javascript 本身不是嚴(yán)格的面向?qū)ο蟮恼Z言(不包含類),實(shí)際上來說,Javascript 并沒有嚴(yán)格的“工廠函數(shù)”,但是在 Javascript中,我們能利用函數(shù)模擬類。來看下面一個例子:

function person(firstName, lastName, age) {
 const person = {};
 person.firstName = firstName;
 person.lastName = lastName;
 person.age = age;
 return person;
}

上述代碼,創(chuàng)建一個新對象,并將傳遞參數(shù)作為屬性附加到該對象上并返回新對象。 這是一個簡單的 JavaScript 工廠函數(shù)。

實(shí)際上工廠函數(shù)也很好理解了:

  • 它是一個函數(shù)。
  • 它用來創(chuàng)建對象。
  • 它像工廠一樣,“生產(chǎn)”出來的函數(shù)都是“標(biāo)準(zhǔn)件”(擁有同樣的屬性)

構(gòu)造函數(shù)

不同于其它的主流編程語言,JavaScript的構(gòu)造函數(shù)并不是作為類的一個特定方法存在的;當(dāng)任意一個普通函數(shù)用于創(chuàng)建一類對象時,它就被稱作構(gòu)造函數(shù),或構(gòu)造器。一個函數(shù)要作為一個真正意義上的構(gòu)造函數(shù),需要滿足下列條件:

  • 在函數(shù)內(nèi)部對新對象(this)的屬性進(jìn)行設(shè)置,通常是添加屬性和方法。
  • 構(gòu)造函數(shù)可以包含返回語句(不推薦),但返回值必須是this,或者其它非對象類型的值。
function Person(firstName, lastName, age) {
 this.firstName = firstName;
 this.lastName = lastName;
 this.age = age;
}

使用 new 關(guān)鍵字創(chuàng)建對象

正如上面所說的,我們可以使用 new 來類或者對象,那么你可能會有以下幾個問題:

  • 我們可以在工廠函數(shù)中使用 new 關(guān)鍵字嗎?
  • 如果我們在工廠和構(gòu)造函數(shù)中使用new關(guān)鍵字會發(fā)生什么
  • 如果在使用構(gòu)造函數(shù)創(chuàng)建對象實(shí)例時不使用new關(guān)鍵字會發(fā)生什么

好的,試著找出以上問題的答案之前,我們先做一個小練習(xí)來理解這里面發(fā)生了什么。

使用new關(guān)鍵字同時使用工廠和構(gòu)造函數(shù)創(chuàng)建兩個對象,接著在控制臺打印這兩個對象。

使用工廠函數(shù)

function person(firstName, lastName, age){
 const person = {}
 person.firstName = firstName;
 person.lastName = lastName;
 person.age = age;
 return person;
}

const mike = new person('mike', 'grand', 23);

正如我們在上述所看到的,這里的__proto__ 指向其原型對象的指針,讓我們試著找出原型對象是什么。為了找出上面mike對象的指向原型對象,讓我們做簡單的===等式檢查。

嗯,有趣的是,它指向 Object.prototype。好的,讓我們用構(gòu)造函數(shù)做同樣的實(shí)驗(yàn)。

理解 JavaScript 的原型

理解原型之前,需要記住以下幾點(diǎn)知識:

  • 所有的引用類型(數(shù)組、對象、函數(shù)),都具有對象特性,即可自由擴(kuò)展屬性(null除外)
  • 所有的引用類型(數(shù)組、對象、函數(shù)),都有一個__proto__屬性,屬性值是一個普通的對象
  • 所有的函數(shù),都有一個prototype屬性,屬性值也是一個普通的對象
  • 所有的引用類型(數(shù)組、對象、函數(shù)),__proto__屬性值指向它的構(gòu)造函數(shù)的prototype屬性值

通過代碼解釋一下:

// 要點(diǎn)一:自由擴(kuò)展屬性
var obj = {}; obj.a = 100;
var arr = []; arr.a = 100;
function fn () {}
fn.a = 100;

// 要點(diǎn)二:__proto__
console.log(obj.__proto__);
console.log(arr.__proto__);
console.log(fn.__proto__);

// 要點(diǎn)三:函數(shù)有 prototype
console.log(fn.prototype)

// 要點(diǎn)四:引用類型的 __proto__ 屬性值指向它的構(gòu)造函數(shù)的 prototype 屬性值
console.log(obj.__proto__ === Object.prototype)

使用構(gòu)造函數(shù)

注意:在JavaScript中,這些構(gòu)造函數(shù)也被稱為 constructor,因?yàn)樗鼈冇糜趧?chuàng)建對象。

function Person(firstName, lastName, age) {
 this.firstName = firstName;
 this.lastName = lastName;
 this.age = age;
}
const mike = new Person('mike', 'grand', 23);

當(dāng)我們展開第一層的的__proto__時,它內(nèi)部還有另一個__proto__,我們再次擴(kuò)展它。

現(xiàn)在讓我們試著弄清楚原型對象是否像上面一樣。

他們是不同的。 當(dāng)我們使用工廠函數(shù)創(chuàng)建對象時,它的__proto__指向Object.prototype,而當(dāng)從構(gòu)造函數(shù)創(chuàng)建對象時,它指向它的構(gòu)造函數(shù)原型對象。 那么這里發(fā)生了什么?

new 背后所做的事

當(dāng)我們在創(chuàng)建對象時使用帶有構(gòu)造函數(shù)的new關(guān)鍵字時,new 背后所做的事不多。

new 運(yùn)算符創(chuàng)建一個用戶自定義的對象類型的實(shí)例或具有構(gòu)造函數(shù)的內(nèi)置對象的實(shí)例。 new 關(guān)鍵字會進(jìn)行如下操作:

  • 創(chuàng)建一個空的簡單 JavaScript 對象 (即 {})
  • 鏈接該對象(即設(shè)置該對象的構(gòu)造函數(shù))到另一個對象
  • 將步驟1新創(chuàng)建的對象作為 this 的上下文
  • 如果該函數(shù)沒有返回對象,則返回 this

注釋行是偽代碼,表示在 new 關(guān)鍵字,JS 背后幫我們做的事情。

function Person(firstName, lastName, age) {
 // this = {};
 // this.__proto__ = Person.prototype;

 this.firstName = firstName;
 this.lastName = lastName;
 this.age = age;
 
 // return this;
}

另外,讓我們看看如果將上面的隱式代碼添加到工廠函數(shù)中會發(fā)生什么。

function person(firstName, lastName, age) {
 // this = {};
 // this.__proto__ = Person.prototype; 
 
 
 const person = {};
 person.firstName = firstName;
 person.lastName = lastName;
 person.age = age;
 return person;
 
 // return this;
}

即使使用new關(guān)鍵字調(diào)用時將隱式代碼添加到工廠函數(shù)中,也不會對結(jié)果產(chǎn)生任何影響。這是因?yàn)椋捎谖覀儧]有在函數(shù)中使用 this 關(guān)鍵字,而且我們顯式地返回了一個除this之外的自定義對象,因此沒有必要使用隱式代碼。無論我們是否對工廠函數(shù)使用new關(guān)鍵字,對輸出都沒有影響。

如果忘記了 new 關(guān)鍵字怎么辦

JavaScript 中有許多概念,有時難以掌握。 new 操作符就是其中之一。 如果你不能正確理解它,那么在運(yùn)行 JavaScript 應(yīng)用程序時會產(chǎn)生令人討厭的后果。 在像 Java這 樣的語言中,嚴(yán)格限制了如何使用 new 關(guān)鍵字。 但是在 javascript 中,并不是那么嚴(yán)格,如果你不能正確理解它們可能會導(dǎo)致很多問題。

在 JavaScript 中:

  • 可以對任何函數(shù)使用 new 運(yùn)算符
  • 可以使用或不使用 new 關(guān)鍵字將函數(shù)作為構(gòu)造函數(shù)調(diào)用

讓我們看看上面的例子,使用和不使用 new 關(guān)鍵情況

function Person(firstName, lastName, age) {
this.firstName = firstName;
this.lastName = lastName;
this.age = age;
}
const mike = new Person('mike', 'grand', 23);
const bob = Person('bob', 'grand', 23);

然后,如果查看創(chuàng)建的對象實(shí)例,你希望看到什么?

發(fā)生了什么? 使用 new 運(yùn)算符,正如我們所期待的一樣輸出正確的對象,但沒有new運(yùn)算符,結(jié)果是undefined 怎么可能呢?

如果你對 JavaScript 作用域 和 this 關(guān)鍵字的工作原理有所了解,那么你可以猜到這里發(fā)生了什么? 讓我們來看看。

看起來我們傳遞給沒有new關(guān)鍵字的函數(shù)的所有屬性都已設(shè)置為window對象。 那是因?yàn)榈侥莻€時候函數(shù)內(nèi)部的這個變量引用了global 或 window 對象,基本上我們在這里做的就是污染了全局對象。

這是你可以對你的JavaScript程序做的非常討厭的事情。 因此,使用new運(yùn)算符,JavaScript引擎將this 變量設(shè)置為引用新創(chuàng)建的對象實(shí)例,這就是為什么我們可以看到傳遞給構(gòu)造函數(shù)的所有屬性都已設(shè)置為 mike。

但是在沒有new運(yùn)算符的情況下調(diào)用構(gòu)造函數(shù)的情況下,JavaScript 引擎會將 this 解釋為常規(guī)函數(shù)調(diào)用,而沒有顯式返回語句時返回undefined。 這就是理解new 運(yùn)算符在JavaScript中的工作原理非常關(guān)鍵的原因。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。

相關(guān)文章

  • JavaScript空數(shù)組的every()方法實(shí)踐

    JavaScript空數(shù)組的every()方法實(shí)踐

    every()方法用于檢測數(shù)組中的所有元素是否都滿足指定條件, 本文主要介紹了JavaScript空數(shù)組的every()方法實(shí)踐,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-03
  • 在頁面中引入js的兩種方法(推薦)

    在頁面中引入js的兩種方法(推薦)

    下面小編就為大家?guī)硪黄陧撁嬷幸雑s的兩種方法(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • JS鍵盤版計(jì)算器的制作方法

    JS鍵盤版計(jì)算器的制作方法

    這篇文章主要為大家詳細(xì)介紹了JS鍵盤版計(jì)算器的制作方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • javascript實(shí)現(xiàn)點(diǎn)擊按鈕變色

    javascript實(shí)現(xiàn)點(diǎn)擊按鈕變色

    這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)點(diǎn)擊按鈕變色,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • JS實(shí)現(xiàn)的簡潔二級導(dǎo)航菜單雛形效果

    JS實(shí)現(xiàn)的簡潔二級導(dǎo)航菜單雛形效果

    這篇文章主要介紹了JS實(shí)現(xiàn)的簡潔二級導(dǎo)航菜單雛形效果,通過簡單的JavaScript響應(yīng)鼠標(biāo)事件遍歷頁面元素實(shí)現(xiàn)二級導(dǎo)航菜單切換的效果,非常簡單實(shí)用,需要的朋友可以參考下
    2015-10-10
  • 微信小程序使用wxParse解析html的方法教程

    微信小程序使用wxParse解析html的方法教程

    這篇文章主要給大家介紹了關(guān)于微信小程序使用wxParse解析html的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07
  • 基于canvas實(shí)現(xiàn)的鐘擺效果完整實(shí)例

    基于canvas實(shí)現(xiàn)的鐘擺效果完整實(shí)例

    這篇文章主要介紹了基于canvas實(shí)現(xiàn)的鐘擺效果,以完整實(shí)例形式分析了JavaScript結(jié)合html5的canvas技術(shù)實(shí)現(xiàn)鐘擺動態(tài)旋轉(zhuǎn)效果的方法,需要的朋友可以參考下
    2016-01-01
  • javascript使用eval或者new Function進(jìn)行語法檢查

    javascript使用eval或者new Function進(jìn)行語法檢查

    使用代碼來實(shí)現(xiàn)分析代碼的語法,這是一件極其痛苦的事情。簡單的解決辦法是:使用腳本引擎自己的語法檢查,比方說eval( ) 或者new Function( )。
    2010-10-10
  • 小程序?qū)崿F(xiàn)左滑刪除的效果的實(shí)例代碼

    小程序?qū)崿F(xiàn)左滑刪除的效果的實(shí)例代碼

    這篇文章主要介紹了小程序?qū)崿F(xiàn)左滑刪除的效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-10-10
  • JavaScript利用發(fā)布訂閱模式編寫事件監(jiān)聽函數(shù)

    JavaScript利用發(fā)布訂閱模式編寫事件監(jiān)聽函數(shù)

    發(fā)布訂閱是一種設(shè)計(jì)模式,EventHub可以被看作是一種Pub/Sub實(shí)現(xiàn)。本文就來講講如何利用eventHub發(fā)布訂閱寫一個事件監(jiān)聽函數(shù),感興趣的可以了解一下
    2023-04-04

最新評論