亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

JavaScript創(chuàng)建對(duì)象的四種方式

2450184176 / 3517人閱讀

摘要:這種方式和有異曲同工之處,因?yàn)槭菍?duì)象的構(gòu)造函數(shù),它的原型對(duì)象也是的方式四這種方式叫做使用對(duì)象字面量創(chuàng)建對(duì)象,這是最簡(jiǎn)單的一種方式,也是我經(jīng)常使用的方法,目的是在于簡(jiǎn)化創(chuàng)建包含大量屬性的對(duì)象的過(guò)程。

關(guān)鍵字

Object.create; new Object(); new Fn(); {}

背景

此段可跳過(guò)不讀……
在平時(shí)的使用中,創(chuàng)建對(duì)象最常用的方式是使用{}直接創(chuàng)建,里面直接寫(xiě)方法和屬性即可;但是在一次實(shí)踐中,將這種方式創(chuàng)建的對(duì)象寫(xiě)在另外的js文件中,在HTML中就不知道怎么使用了,百度許久之后使用了Object.create的方式,想不到遇到了新的坑,這種方式只支持ES5以上,在低版本中,需要進(jìn)行兼容處理,現(xiàn)在將這幾種創(chuàng)建對(duì)象的方式進(jìn)行整理,以便日后翻閱。

方式一: Object.create 1. 語(yǔ)法

var newObj = Object.create(proto, propertyObject);
參數(shù):
proto:新創(chuàng)建對(duì)象的原型對(duì)象
propertyObject: 新創(chuàng)建對(duì)象的可枚舉屬性,相當(dāng)于Object.defineProperty()中的第二個(gè)參數(shù)一樣
返回值: 新創(chuàng)建的對(duì)象

var aa = {
    valA:1, 
    fnA: function(){console.log(this.valA)}
};

var bb = Object.create(aa, {
  // foo會(huì)成為所創(chuàng)建對(duì)象的數(shù)據(jù)屬性
  foo: { 
    writable:true,
    configurable:true,
    value: "hello" 
  },
  // bar會(huì)成為所創(chuàng)建對(duì)象的訪問(wèn)器屬性
  bar: {
    configurable: false,
    get: function() { return 10 },
    set: function(value) {
      console.log("Setting `o.bar` to", value);
    }
  }
});

結(jié)果是:bb可以訪問(wèn)的屬性有:
(1)它自身的foo和bar
(2)aa的valA和fnA
且,bb.__proto__ == aa

2.polyfill

對(duì)于ES5以下不支持這種方式的瀏覽器來(lái)說(shuō),可以用以下方式進(jìn)行兼容,這也是Object.create的polyfill;

if (typeof Object.create !== "function") {
  Object.create = function (proto, propertiesObject) {
      if (typeof proto !== "object" && typeof proto !== "function") {
          throw new TypeError("Object prototype may only be an Object: " + proto);
      } else if (proto === null) {
          throw new Error("This browser"s implementation of Object.create is a shim and doesn"t support "null" as the first argument.");
      }
      if (typeof propertiesObject != "undefined") throw new Error("This browser"s implementation of Object.create is a shim and doesn"t support a second argument.");
      function F() {}
      F.prototype = proto;
      return new F();
  };
}

總之,記住一句話,新對(duì)象的原型是proto,proto是Object.create的第一個(gè)參數(shù)

3.彩蛋

附贈(zèng)兩張圖,也許有用,鏘鏘鏘~~~~


好吧,萬(wàn)一打不開(kāi)圖,圖一是說(shuō),在ES5中新增的對(duì)象方法有create&keys、defineProperty,String的方法有trim,數(shù)組的方法有indexOf、filter&map、foreach。
圖二是支持ES5的瀏覽器,其中Chrome支持還可以,IE只能到IE11才能比較好的支持;

方式二:new 構(gòu)造函數(shù)

這種方式也很常用,尤其是做繼承什么的,擴(kuò)展性和封裝性比較好

function Person(){
    this.name = "****";
    this.age = 11,
    this.getAge = function(){}
}

可以使用

var p = new Person();

將p打印出來(lái)就是

{
    name: "****";
    age: 11,
    getAge: function(){},
    __proto__: Object
}
pp.constructor == Person  ==> **true**
Person.__proto__ == Function.prototype   ==> **true**
方式三:new Object() 1.創(chuàng)建一個(gè)空對(duì)象
var obj = new Object();

等價(jià)于

var obj = {};

可以繼續(xù)進(jìn)行擴(kuò)展屬性和方法

2.
var aa = {
    valA:1, 
    fnA: function(){console.log(this.valA)}
};
var oo = new Object(aa);

結(jié)果是:

oo === aa    ==> true
oo.valA = 2;
console.log(aa.valA)   ==> 2

說(shuō)明oo是aa的淺拷貝,和對(duì)象直接復(fù)制一樣,我也不知道為什么我要這么測(cè)試。。。。

這種方式和new Person有“異曲同工”之處,因?yàn)椋?br>Object.__proto__ == Function.protoType
Person.__proto__ == Function.protoType
Object是對(duì)象的構(gòu)造函數(shù),它的原型對(duì)象也是Function的prototype

方式四:{}

這種方式叫做:使用對(duì)象字面量創(chuàng)建對(duì)象,這是最簡(jiǎn)單的一種方式,也是我經(jīng)常使用的方法,目的是在于簡(jiǎn)化創(chuàng)建包含大量屬性的對(duì)象的過(guò)程。

var person = {
   name: "*****",
   age: 11,
   getAge: function(){
    return this.age;
   },
   setAge: function(newAge){
    this.age = newAge;
   } 
}
調(diào)用時(shí):
person.name
person["name"]
擴(kuò)展屬性時(shí):
person.hairColor = "black";
person.getName = function(){};

有人做過(guò)測(cè)試,這種方式比使用new Object()創(chuàng)建對(duì)象更快,因?yàn)閧}是立即求值的,而new Object()本質(zhì)上是方法,既然是方法,就涉及到在原型中遍歷該方法,當(dāng)找到這個(gè)方法時(shí),又會(huì)產(chǎn)生調(diào)用方法必須的堆棧信息,方法調(diào)用結(jié)束之后,又要釋放堆棧信息,所以會(huì)慢一些。

總結(jié)

這是幾種常用的創(chuàng)建對(duì)象的方式,我比較常用的是方式四和方式二,方式四比較直接快速,方式二經(jīng)常用來(lái)做繼承之類;方式一的需要考慮兼容ES5的問(wèn)題,它可以擴(kuò)展一些新對(duì)象的可枚舉屬性,總感覺(jué)和defineProperty有某些聯(lián)系吧,但是還不太懂,還煩請(qǐng)各位大神多多指教吧。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/95976.html

相關(guān)文章

  • JavaScript 異步編程四種方式

    摘要:異步編程是每個(gè)使用編程的人都會(huì)遇到的問(wèn)題,無(wú)論是前端的請(qǐng)求,或是的各種異步。本文就來(lái)總結(jié)一下常見(jiàn)的四種處理異步編程的方法。利用一種鏈?zhǔn)秸{(diào)用的方法來(lái)組織異步代碼,可以將原來(lái)以回調(diào)函數(shù)形式調(diào)用的代碼改為鏈?zhǔn)秸{(diào)用。 異步編程是每個(gè)使用 JavaScript 編程的人都會(huì)遇到的問(wèn)題,無(wú)論是前端的 ajax 請(qǐng)求,或是 node 的各種異步 API。本文就來(lái)總結(jié)一下常見(jiàn)的四種處理異步編程的方法。...

    microelec 評(píng)論0 收藏0
  • [摘譯]js內(nèi)存泄漏常見(jiàn)四種情況

    摘要:本文主要選取了這篇文章中的一小部分來(lái)說(shuō)明一下中產(chǎn)生內(nèi)存泄漏的常見(jiàn)情況對(duì)于較難理解的第四種情況參考了一些文章來(lái)進(jìn)行說(shuō)明意外的全局變量中如果不用聲明變量該變量將被視為對(duì)象全局對(duì)象的屬性也就是全局變量上面的函數(shù)等價(jià)于所以你調(diào)用完了函數(shù)以后變量仍然 本文主要選取了4 Types of Memory Leaks in JavaScript and How to Get Rid Of Them 這...

    Moxmi 評(píng)論0 收藏0
  • Javascript獲取原型四種方法

    基礎(chǔ)代碼: function R(){} let obj=new R(); 2:第一種方式 console.log(Object.getPrototypeOf(obj)); 3:第二種方式 console.log(obj.__proto__); 4:第三種方式 console.log(obj.constructor.__proto__); 5:第四種方式: console.log(R.proto...

    Jeffrrey 評(píng)論0 收藏0
  • react創(chuàng)建組建四種方式

    摘要:原由寫(xiě)這篇文章主要是為了增強(qiáng)自己的記憶,同時(shí)也是為了分享一下我們常用的創(chuàng)建組建的方法,主要是四種,啟發(fā)來(lái)自于不知的博客呀,有興趣的人可以去看看他的博客敘述我們?cè)谟玫臅r(shí)候考慮最多的其實(shí)就是如何策劃組建的劃分,組建的嵌套,能夠做到更省時(shí)省力。 原由:寫(xiě)這篇文章主要是為了增強(qiáng)自己的記憶,同時(shí)也是為了分享一下我們常用的創(chuàng)建組建的方法,主要是四種(createClass, component, ...

    XanaHopper 評(píng)論0 收藏0
  • ??ASP.NET 使用 Dispose 釋放資源四種方法?

    Dispose 和 Finalize 是運(yùn)行的 .NET 和 .NET Core 應(yīng)用程序釋放占用的資源的兩種方法。通常,如果應(yīng)用程序中有非托管資源,應(yīng)該顯式地釋放這些資源占用的資源。由于 Finalize 的非確定性,以及在性能方面的成本很高,因此 Dispose 方法的使用頻率遠(yuǎn)高于 Finalize。其實(shí),我們可以在一個(gè)實(shí)現(xiàn)了 IDisposable 接口的類型上使用 Dispose 方法。...

    bovenson 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<