茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    深入理解JavaScript系列(26):設(shè)計(jì)模式之構(gòu)造函數(shù)模式詳解
    來(lái)源:易賢網(wǎng) 閱讀:952 次 日期:2015-03-06 10:51:22
    溫馨提示:易賢網(wǎng)小編為您整理了“深入理解JavaScript系列(26):設(shè)計(jì)模式之構(gòu)造函數(shù)模式詳解”,方便廣大網(wǎng)友查閱!

    這篇文章主要介紹了深入理解JavaScript系列(26):設(shè)計(jì)模式之構(gòu)造函數(shù)模式詳解,本文講解了基本用法、構(gòu)造函數(shù)與原型、只能用new嗎?、強(qiáng)制使用new、原始包裝函數(shù)等內(nèi)容,需要的朋友可以參考下

    介紹

    構(gòu)造函數(shù)大家都很熟悉了,不過(guò)如果你是新手,還是有必要來(lái)了解一下什么叫構(gòu)造函數(shù)的。構(gòu)造函數(shù)用于創(chuàng)建特定類(lèi)型的對(duì)象——不僅聲明了使用的對(duì)象,構(gòu)造函數(shù)還可以接受參數(shù)以便第一次創(chuàng)建對(duì)象的時(shí)候設(shè)置對(duì)象的成員值。你可以自定義自己的構(gòu)造函數(shù),然后在里面聲明自定義類(lèi)型對(duì)象的屬性或方法。

    基本用法

    在JavaScript里,構(gòu)造函數(shù)通常是認(rèn)為用來(lái)實(shí)現(xiàn)實(shí)例的,JavaScript沒(méi)有類(lèi)的概念,但是有特殊的構(gòu)造函數(shù)。通過(guò)new關(guān)鍵字來(lái)調(diào)用定義的否早函數(shù),你可以告訴JavaScript你要?jiǎng)?chuàng)建一個(gè)新對(duì)象并且新對(duì)象的成員聲明都是構(gòu)造函數(shù)里定義的。在構(gòu)造函數(shù)內(nèi)部,this關(guān)鍵字引用的是新創(chuàng)建的對(duì)象?;居梅ㄈ缦拢?/P>

    代碼如下:

    function Car(model, year, miles) {

    this.model = model;

    this.year = year;

    this.miles = miles;

    this.output= function () {

    return this.model + "走了" + this.miles + "公里";

    };

    }

    var tom= new Car("大叔", 2009, 20000);

    var dudu= new Car("Dudu", 2010, 5000);

    console.log(tom.output());

    console.log(dudu.output());

    上面的例子是個(gè)非常簡(jiǎn)單的構(gòu)造函數(shù)模式,但是有點(diǎn)小問(wèn)題。首先是使用繼承很麻煩了,其次output()在每次創(chuàng)建對(duì)象的時(shí)候都重新定義了,最好的方法是讓所有Car類(lèi)型的實(shí)例都共享這個(gè)output()方法,這樣如果有大批量的實(shí)例的話(huà),就會(huì)節(jié)約很多內(nèi)存。

    解決這個(gè)問(wèn)題,我們可以使用如下方式:

    代碼如下:

    function Car(model, year, miles) {

    this.model = model;

    this.year = year;

    this.miles = miles;

    this.output= formatCar;

    }

    function formatCar() {

    return this.model + "走了" + this.miles + "公里";

    }

    這個(gè)方式雖然可用,但是我們有如下更好的方式。

    構(gòu)造函數(shù)與原型

    JavaScript里函數(shù)有個(gè)原型屬性叫prototype,當(dāng)調(diào)用構(gòu)造函數(shù)創(chuàng)建對(duì)象的時(shí)候,所有該構(gòu)造函數(shù)原型的屬性在新創(chuàng)建對(duì)象上都可用。按照這樣,多個(gè)Car對(duì)象實(shí)例可以共享同一個(gè)原型,我們?cè)贁U(kuò)展一下上例的代碼:

    代碼如下:

    function Car(model, year, miles) {

    this.model = model;

    this.year = year;

    this.miles = miles;

    }

    /*

    注意:這里我們使用了Object.prototype.方法名,而不是Object.prototype

    主要是用來(lái)避免重寫(xiě)定義原型prototype對(duì)象

    */

    Car.prototype.output= function () {

    return this.model + "走了" + this.miles + "公里";

    };

    var tom = new Car("大叔", 2009, 20000);

    var dudu = new Car("Dudu", 2010, 5000);

    console.log(tom.output());

    console.log(dudu.output());

    這里,output()單實(shí)例可以在所有Car對(duì)象實(shí)例里共享使用。

    另外:我們推薦構(gòu)造函數(shù)以大寫(xiě)字母開(kāi)頭,以便區(qū)分普通的函數(shù)。

    只能用new嗎?

    上面的例子對(duì)函數(shù)car都是用new來(lái)創(chuàng)建對(duì)象的,只有這一種方式么?其實(shí)還有別的方式,我們列舉兩種:

    代碼如下:

    function Car(model, year, miles) {

    this.model = model;

    this.year = year;

    this.miles = miles;

    // 自定義一個(gè)output輸出內(nèi)容

    this.output = function () {

    return this.model + "走了" + this.miles + "公里";

    }

    }

    //方法1:作為函數(shù)調(diào)用

    Car("大叔", 2009, 20000); //添加到window對(duì)象上

    console.log(window.output());

    //方法2:在另外一個(gè)對(duì)象的作用域內(nèi)調(diào)用

    var o = new Object();

    Car.call(o, "Dudu", 2010, 5000);

    console.log(o.output());

    該代碼的方法1有點(diǎn)特殊,如果不適用new直接調(diào)用函數(shù)的話(huà),this指向的是全局對(duì)象window,我們來(lái)驗(yàn)證一下:

    代碼如下:

    //作為函數(shù)調(diào)用

    var tom = Car("大叔", 2009, 20000);

    console.log(typeof tom); // "undefined"

    console.log(window.output()); // "大叔走了20000公里"

    這時(shí)候?qū)ο髏om是undefined,而window.output()會(huì)正確輸出結(jié)果,而如果使用new關(guān)鍵字則沒(méi)有這個(gè)問(wèn)題,驗(yàn)證如下:

    代碼如下:

    //使用new 關(guān)鍵字

    var tom = new Car("大叔", 2009, 20000);

    console.log(typeof tom); // "object"

    console.log(tom.output()); // "大叔走了20000公里"

    強(qiáng)制使用new

    上述的例子展示了不使用new的問(wèn)題,那么我們有沒(méi)有辦法讓構(gòu)造函數(shù)強(qiáng)制使用new關(guān)鍵字呢,答案是肯定的,上代碼:

    代碼如下:

    function Car(model, year, miles) {

    if (!(this instanceof Car)) {

    return new Car(model, year, miles);

    }

    this.model = model;

    this.year = year;

    this.miles = miles;

    this.output = function () {

    return this.model + "走了" + this.miles + "公里";

    }

    }

    var tom = new Car("大叔", 2009, 20000);

    var dudu = Car("Dudu", 2010, 5000);

    console.log(typeof tom); // "object"

    console.log(tom.output()); // "大叔走了20000公里"

    console.log(typeof dudu); // "object"

    console.log(dudu.output()); // "Dudu走了5000公里"

    通過(guò)判斷this的instanceof是不是Car來(lái)決定返回new Car還是繼續(xù)執(zhí)行代碼,如果使用的是new關(guān)鍵字,則(this instanceof Car)為真,會(huì)繼續(xù)執(zhí)行下面的參數(shù)賦值,如果沒(méi)有用new,(this instanceof Car)就為假,就會(huì)重新new一個(gè)實(shí)例返回。

    原始包裝函數(shù)

    JavaScript里有3中原始包裝函數(shù):number, string, boolean,有時(shí)候兩種都用:

    代碼如下:

    // 使用原始包裝函數(shù)

    var s = new String("my string");

    var n = new Number(101);

    var b = new Boolean(true);

     

    // 推薦這種

    var s = "my string";

    var n = 101;

    var b = true;

    推薦,只有在想保留數(shù)值狀態(tài)的時(shí)候使用這些包裝函數(shù),關(guān)于區(qū)別可以參考下面的代碼:

    代碼如下:

    // 原始string

    var greet = "Hello there";

    // 使用split()方法分割

    greet.split(' ')[0]; // "Hello"

    // 給原始類(lèi)型添加新屬性不會(huì)報(bào)錯(cuò)

    greet.smile = true;

    // 單沒(méi)法獲取這個(gè)值(18章ECMAScript實(shí)現(xiàn)里我們講了為什么)

    console.log(typeof greet.smile); // "undefined"

    // 原始string

    var greet = new String("Hello there");

    // 使用split()方法分割

    greet.split(' ')[0]; // "Hello"

    // 給包裝函數(shù)類(lèi)型添加新屬性不會(huì)報(bào)錯(cuò)

    greet.smile = true;

    // 可以正常訪問(wèn)新屬性

    console.log(typeof greet.smile); // "boolean"

    總結(jié)

    本章主要講解了構(gòu)造函數(shù)模式的使用方法、調(diào)用方法以及new關(guān)鍵字的區(qū)別,希望大家在使用的時(shí)候有所注意。

    更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄

    更多信息請(qǐng)查看腳本欄目
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢(xún)回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢(xún)?yōu)闇?zhǔn)!

    2026上岸·考公考編培訓(xùn)報(bào)班

    • 報(bào)班類(lèi)型
    • 姓名
    • 手機(jī)號(hào)
    • 驗(yàn)證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢(xún) | 簡(jiǎn)要咨詢(xún)須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
    工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
    云南網(wǎng)警備案專(zhuān)用圖標(biāo)
    聯(lián)系電話(huà):0871-65099533/13759567129 獲取招聘考試信息及咨詢(xún)關(guān)注公眾號(hào):hfpxwx
    咨詢(xún)QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)