欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript設(shè)計(jì)模式Constructor(構(gòu)造器)模式

 更新時(shí)間:2016年08月19日 09:48:44   作者:yilanyoumeng3  
這篇文章主要為大家詳細(xì)介紹了javascript設(shè)計(jì)模式Constructor(構(gòu)造器)模式 ,感興趣的小伙伴們可以參考一下

Constructor是一種在內(nèi)存已分配給該對(duì)象的情況下,用于初始化新創(chuàng)建對(duì)象的特殊方法。Object構(gòu)造器用于創(chuàng)建特定類型的對(duì)象–準(zhǔn)備好對(duì)象以備使用,同事接收構(gòu)造器可以使用參數(shù),以在第一次創(chuàng)建對(duì)象時(shí),設(shè)置成員屬性和方法值。

對(duì)象創(chuàng)建
創(chuàng)新新對(duì)象,在javascript中通常有兩種方法:
 1.對(duì)象直面量方法
var newObj = {};

 2.構(gòu)造器的簡(jiǎn)潔方法
var newObj = new Object();
在Object構(gòu)造器為特定的值創(chuàng)建對(duì)象封裝,或者沒(méi)有傳遞值時(shí),它將創(chuàng)建一個(gè)肯那個(gè)對(duì)象并返回

 對(duì)象賦值的方法:
 1.“點(diǎn)”方法

 //設(shè)置屬性
newObj.name = 'LanFeng';
//獲取值
var user= newObj.name;

 1.中括號(hào)方法

 //設(shè)置屬性
newObj["name"]= 'LanFeng';
//獲取值
var user= newObj["name"];

 1.Object.defineProperty (適用ECMAScript5)

 //設(shè)置屬性
Object.defineProperty(newObj,"name",{
  value:"LanFeng",
  writable:true,
  enumerable:true,
  configurable:true
})

 1.Object.defineProperties

 //設(shè)置屬性
 Object.defineProperties(newObj,{
   "someKey":{
    value:"Hello Js",
     writable:true
  },
  "anotherKey":{
    value:"Foo bar",
    writable:false
  }
})

Javascript不支持類的概念,但它確實(shí)支持與對(duì)象一起用的特殊constructor函數(shù),通過(guò)在構(gòu)造器前面加new關(guān)鍵字,告訴js像使用構(gòu)造器一樣實(shí)例化一個(gè)新對(duì)象,并且對(duì)象成員由該函數(shù)定義。
在構(gòu)造器內(nèi),關(guān)鍵字this引用新創(chuàng)建的對(duì)象。回顧對(duì)象創(chuàng)建,基本的構(gòu)造器:

function Car(model,year,miles){
  this.model = model;
  this.year = year;
  this.miles = miles;
  this.toString = function(){
  return this.model + "has done" + this.miles +"miles";
  }
}
//創(chuàng)建實(shí)例化對(duì)象

var civio = new Car("Honda Civio",2009,20000);

var mondeo= new Car("Ford Mondeo",2009,5000);

上面例子是一個(gè)簡(jiǎn)單的構(gòu)造器模式版本,但它確實(shí)存在一些問(wèn)題,其中一個(gè)問(wèn)題是,它使用繼承變得困難,另外一個(gè)問(wèn)題是,toString()這樣的函數(shù)是為每個(gè)使用Car構(gòu)造器創(chuàng)建的新對(duì)象而分別重新定義的,這個(gè)不是最理想的,因?yàn)檫@種函數(shù)應(yīng)該在所有的Car類型實(shí)例直接共享。

javascript中有有一個(gè)prototype的屬性,調(diào)用js構(gòu)造器創(chuàng)建一個(gè)對(duì)象后,新對(duì)象就會(huì)具有構(gòu)造器原型的所有屬性,通過(guò)這種方式,可以創(chuàng)建多個(gè)對(duì)象,并訪問(wèn)相同的原型,實(shí)現(xiàn)方法共享。

function Car(model,year,miles){
  this.model = model;
  this.year = year;
  this.miles = miles;

}


//原型函數(shù)
Car.prototype.toString = function(){
  return this.model + "has done" + this.miles +"miles";
  }

//創(chuàng)建實(shí)例化對(duì)象

var civio = new Car("Honda Civio",2009,20000);
var mondeo= new Car("Ford Mondeo",2009,5000);
console.log(civio.toString())
console.log(mondeo.toString())

現(xiàn)在toString()的單一實(shí)例就能夠在所有Car對(duì)著之間共享。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 微信小程序wxs日期時(shí)間處理的實(shí)現(xiàn)示例

    微信小程序wxs日期時(shí)間處理的實(shí)現(xiàn)示例

    最近在做一個(gè)列表的時(shí)候,涉及到時(shí)間格式化操作。本文主要介紹了微信小程序wxs日期時(shí)間處理的實(shí)現(xiàn)示例,分享給大家,感興趣的可以了解一下
    2021-07-07
  • 如何處理JSON中的特殊字符

    如何處理JSON中的特殊字符

    這篇文章主要介紹了如何處理JSON中的特殊字符,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-11-11
  • JS幻燈片可循環(huán)播放可平滑旋轉(zhuǎn)帶滾動(dòng)導(dǎo)航(自寫)

    JS幻燈片可循環(huán)播放可平滑旋轉(zhuǎn)帶滾動(dòng)導(dǎo)航(自寫)

    本文為大家介紹下實(shí)現(xiàn)JS幻燈片可循環(huán)播放帶滾動(dòng)導(dǎo)航可平滑旋轉(zhuǎn)的全過(guò)程,效果還不錯(cuò),由需要的朋友可以參考下,希望對(duì)大家有所幫助
    2013-08-08
  • webpack5新特性Asset?Modules資源模塊詳解

    webpack5新特性Asset?Modules資源模塊詳解

    這篇文章主要為大家介紹了webpack5新特性Asset?Modules資源模塊詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • KnockoutJS 3.X API 第四章之click綁定

    KnockoutJS 3.X API 第四章之click綁定

    click綁定主要作用是用于DOM元素被點(diǎn)擊時(shí)調(diào)用相關(guān)JS函數(shù)。這篇文章主要介紹了KnockoutJS 3.X API 第四章之click綁定,感興趣的朋友一起看看吧
    2016-10-10
  • 如何基于filter實(shí)現(xiàn)網(wǎng)站整體變灰功能

    如何基于filter實(shí)現(xiàn)網(wǎng)站整體變灰功能

    這篇文章主要介紹了如何基于filter實(shí)現(xiàn)網(wǎng)站整體變灰功能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 微信小程序獲取用戶信息并保存登錄狀態(tài)詳解

    微信小程序獲取用戶信息并保存登錄狀態(tài)詳解

    這篇文章主要介紹了微信小程序獲取用戶信息并保存登錄狀態(tài),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • 微信小程序頂部導(dǎo)航欄滑動(dòng)tab效果

    微信小程序頂部導(dǎo)航欄滑動(dòng)tab效果

    這篇文章主要為大家詳細(xì)介紹了微信小程序頂部導(dǎo)航欄滑動(dòng)tab效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • JavaScript中DOM操作常用事件總結(jié)

    JavaScript中DOM操作常用事件總結(jié)

    這篇文章主要為大家詳細(xì)介紹了JavaScript中常用的幾個(gè)DOM事件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-04-04
  • JS加載解析Markdown文檔過(guò)程詳解

    JS加載解析Markdown文檔過(guò)程詳解

    這篇文章主要介紹了JS加載解析Markdown文檔過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05

最新評(píng)論