中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

深入理解JavaScript系列(26):設(shè)計(jì)模式之構(gòu)造函數(shù)模式詳解
來(lái)源:易賢網(wǎng) 閱讀:995 次 日期: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)建特定類型的對(duì)象——不僅聲明了使用的對(duì)象,構(gòu)造函數(shù)還可以接受參數(shù)以便第一次創(chuàng)建對(duì)象的時(shí)候設(shè)置對(duì)象的成員值。你可以自定義自己的構(gòu)造函數(shù),然后在里面聲明自定義類型對(duì)象的屬性或方法。

基本用法

在JavaScript里,構(gòu)造函數(shù)通常是認(rèn)為用來(lái)實(shí)現(xiàn)實(shí)例的,JavaScript沒有類的概念,但是有特殊的構(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ì)象。基本用法如下:

代碼如下:

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類型的實(shí)例都共享這個(gè)output()方法,這樣如果有大批量的實(shí)例的話,就會(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)避免重寫定義原型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ù)以大寫字母開頭,以便區(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ù)的話,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)鍵字則沒有這個(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)題,那么我們有沒有辦法讓構(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ù)賦值,如果沒有用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"

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

greet.smile = true;

// 單沒法獲取這個(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ù)類型添加新屬性不會(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ù)專欄

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

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

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎ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)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
1024国产精品| 久久青青草综合| 国产一区二区精品久久99| 国产精品揄拍500视频| 国产日韩精品久久| 亚洲国产日韩一级| 亚洲伊人久久综合| 久久看片网站| 欧美日韩三级一区二区| 国产日韩欧美日韩| 亚洲高清自拍| 亚洲欧美精品| 久久国产福利国产秒拍| 裸体素人女欧美日韩| 国产精品地址| 黄色工厂这里只有精品| 在线观看视频欧美| 日韩视频一区二区三区| 亚洲一区免费看| 亚洲乱码国产乱码精品精天堂| 国产美女诱惑一区二区| 国产欧美一区二区三区久久| 欧美激情一区二区| 免费亚洲一区二区| 欧美日韩国产成人在线免费| 久久aⅴ国产欧美74aaa| 久久精品理论片| 男女视频一区二区| 国产精品sm| 黄色精品在线看| 亚洲色无码播放| 久久婷婷人人澡人人喊人人爽| 欧美激情五月| 国产日韩亚洲欧美| 日韩视频―中文字幕| 久久aⅴ国产紧身牛仔裤| 欧美福利视频在线观看| 国产精品视频久久| 亚洲国产婷婷香蕉久久久久久| 亚洲欧洲日韩在线| 欧美一区二区三区久久精品| 欧美精品v日韩精品v国产精品| 国产热re99久久6国产精品| 亚洲国产欧美不卡在线观看| 亚洲免费一级电影| 欧美区视频在线观看| 欧美性理论片在线观看片免费| 国产主播一区二区三区| 午夜激情综合网| 欧美美女视频| 亚洲福利视频一区| 久久精品成人欧美大片古装| 欧美日韩亚洲三区| 在线日韩精品视频| 欧美专区亚洲专区| 国产精品日韩电影| 99re6热只有精品免费观看 | 国产精品高潮呻吟| 亚洲国产另类久久精品| 香蕉成人久久| 国产精品麻豆成人av电影艾秋| 最新成人av在线| 久久婷婷一区| 狠狠色狠狠色综合| 久久电影一区| 国产精品美女午夜av| 亚洲精品日日夜夜| 久久夜色精品国产欧美乱极品 | 欧美理论电影在线播放| 一区在线电影| 免费久久99精品国产自| 在线观看成人小视频| 久久精品国产999大香线蕉| 国产精品豆花视频| 一本色道精品久久一区二区三区| 欧美成人精品在线观看| 久久aⅴ乱码一区二区三区| 国产精品视频yy9299一区| 亚洲桃花岛网站| 国产精品久久一区二区三区| 亚洲午夜久久久| 国产精品极品美女粉嫩高清在线| 在线综合欧美| 国产精品v欧美精品v日本精品动漫| 一区二区三区欧美亚洲| 欧美午夜在线观看| 一本色道久久综合狠狠躁篇的优点| 久久久久久久综合| 国产色产综合产在线视频| 亚洲一级二级| 国产精品久久77777| 欧美一区二区在线免费观看 | 亚洲电影成人| 男女精品视频| 99国产精品视频免费观看| 欧美日韩系列| 午夜日韩av| 国产一区二区三区av电影 | 亚洲欧洲一区二区在线播放| 香蕉尹人综合在线观看| 国产午夜精品理论片a级探花| 久久裸体艺术| 亚洲韩国日本中文字幕| 欧美日韩一区二区在线观看视频| 在线亚洲免费| 黑丝一区二区| 欧美激情亚洲综合一区| 日韩视频三区| 国产麻豆精品theporn| 欧美在线视频在线播放完整版免费观看| 韩国av一区二区三区在线观看 | 久久久视频精品| 亚洲国产精品专区久久| 欧美日韩一视频区二区| 午夜精品视频网站| 黄色成人在线免费| 欧美精品乱码久久久久久按摩| 亚洲视频中文| 激情一区二区三区| 欧美日韩爆操| 久久成人免费网| 亚洲卡通欧美制服中文| 国产欧美日本一区二区三区| 另类人畜视频在线| 一区二区三区国产在线观看| 国产在线不卡视频| 欧美日韩国产欧美日美国产精品| 欧美与欧洲交xxxx免费观看| 久久久精品国产一区二区三区| 亚洲精品中文字| 国产一区二区黄色| 欧美三区在线| 欧美国产一区二区在线观看| 欧美一区二视频| 日韩午夜激情| 在线日韩av| 国产一区二区三区的电影 | 国产精品成人在线观看| 久久一区视频| 欧美一区二区视频免费观看| 一区二区激情| 亚洲国产女人aaa毛片在线| 国产一区二区三区免费在线观看| 欧美日韩欧美一区二区| 欧美大胆成人| 鲁大师影院一区二区三区| 久久国产精品久久久久久久久久| 一区二区日韩伦理片| 亚洲欧洲免费视频| 狠狠色狠狠色综合| 国产精品视频| 欧美三日本三级少妇三2023| 欧美国产精品久久| 久久精品一区二区国产| 亚洲亚洲精品在线观看 | 亚洲欧洲精品一区二区三区不卡| 国产亚洲免费的视频看| 国产精品毛片一区二区三区| 欧美日韩一区二区三区视频 | 欧美激情欧美狂野欧美精品 | 国产精品福利av| 欧美日韩国产成人在线91| 欧美精品少妇一区二区三区| 欧美国产在线视频| 欧美成人在线免费视频| 久久综合九色九九| 美女国产精品| 老司机aⅴ在线精品导航| 久久精品中文字幕免费mv| 久久se精品一区二区| 欧美一区二区三区久久精品茉莉花 | 欧美精品在线网站| 欧美大片免费| 欧美国产日韩精品| 欧美精品色综合| 欧美色大人视频| 国产精品毛片| 在线中文字幕一区| 99精品欧美一区二区蜜桃免费| 狠狠色狠狠色综合| 亚洲电影成人| 日韩视频免费观看高清在线视频| 亚洲日本理论电影| 一区二区三区视频免费在线观看| 亚洲少妇中出一区| 香蕉精品999视频一区二区| 欧美伊人影院| 另类亚洲自拍| 欧美日韩国产成人在线| 国产精品高潮在线| 国产视频一区免费看| 好吊色欧美一区二区三区视频| 亚洲成人资源| 亚洲裸体视频| 亚洲欧美在线免费| 久久成人18免费网站| 欧美高清不卡| 国产精品色网| 1000精品久久久久久久久| 99视频国产精品免费观看|