国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務(wù)器之家 - 編程語言 - JavaScript - js教程 - js 創(chuàng)建對象的多種方式與優(yōu)缺點小結(jié)

js 創(chuàng)建對象的多種方式與優(yōu)缺點小結(jié)

2022-02-15 18:13feng js教程

這篇文章主要介紹了js 創(chuàng)建對象的多種方式與優(yōu)缺點,幫助大家更好的理解和學(xué)習(xí)使用JavaScript,感興趣的朋友可以了解下

早期創(chuàng)建方式

?
1
2
3
4
5
6
7
8
9
10
11
12
var obj = new Object()
obj.name ='xxx'
obj.age = 18
或使用對象字面量
var o1 = {
  name: 'xxx',
  say: () => {}
}
var o2 = {
  name: 'xxx',
  say: () => {}
}

缺點:使用同一個接口創(chuàng)建很多對象,會產(chǎn)生大量重復(fù)代碼

工廠模式

?
1
2
3
4
5
6
7
8
function factory(name,age) {
  var obj = new Object()
  obj.name = name
  obj.age = age
  return obj
}
var o1 = factory(1, 11)
var o2 = factory(2, 22)

優(yōu)點:解決了創(chuàng)建多個相似對象代碼重復(fù)問題
缺點:無法識別對象是什么類型

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

ECMAScript中可以使用構(gòu)造函數(shù)創(chuàng)建特定類型的對象,如Object,Array這種原生構(gòu)造函數(shù)。此外,也可以創(chuàng)建自定義構(gòu)造函數(shù),從而定義自定義對象的屬性和方法。

?
1
2
3
4
5
6
7
8
9
10
11
function Person(name, age) {
  this.name = name
  this.age = age
  this.sayName = function() {
    console.log(this.name)
  }
}
var o1 = new Person(1,11)
var o2 = new Person(2,22)
o1.sayName() // 1
o2.sayName() // 2

優(yōu)點:構(gòu)造函數(shù)模式創(chuàng)建的實例可以區(qū)分類型標識(instanceof 判斷)
缺點:每個方法都需要在實例上重新創(chuàng)建,如 兩個實例的sayName方法任務(wù)相同,但是實際創(chuàng)建了兩個Function實例

構(gòu)造函數(shù)模式優(yōu)化

?
1
2
3
4
5
6
7
8
9
10
11
function Person(name, age) {
  this.name = name
  this.age = age
}
function sayName () {
  console.log(this.name)
}
var o1 = new Person(1,11)
var o2 = new Person(2,22)
o1.sayName() // 1
o2.sayName() // 2

優(yōu)點:多個實例共享在全局作用域中定義的函數(shù),解決了兩個函數(shù)做同一件事的問題
缺點:全局作用域定義的函數(shù)實際上只能被某個對象調(diào)用,全局作用域名不副實,而且如果對象需要定義很多方法,需要創(chuàng)建很多個全局函數(shù),這讓自定義的對象類型沒有封裝特性。

原型模式

我們創(chuàng)建的每個函數(shù)都有一個protoype屬性,這個屬性是一個指針,指向一個對象。這個對象的用途是包含了可以由特定類型的所有實例共享的屬性和方法。即prototype就是由構(gòu)造函數(shù)創(chuàng)建的那個對象實例的原型對象。

?
1
2
3
4
5
6
7
8
9
10
function Person(){}
Person.prototype.name = '123'
Person.prototype.age = 18
Person.prototype.sayName = function() {
  console.log(this.name)
}
var o1 = new Person(1,11)
var o2 = new Person(2,22)
o1.sayName() // 123
o2.sayName() // 123

優(yōu)點:解決了實例共享屬性或事件的問題
缺點:因為實例共享屬性的原因,對于值為引用類型的屬性來說,一個實例的修改會導(dǎo)致其他實例訪問值更改。如:

?
1
2
3
4
5
6
7
8
9
10
11
function Person(){}
Person.prototype.name = '123'
Person.prototype.age = 18
Person.prototype.friends = ['a', 'b']
Person.prototype.sayName = function() {
  console.log(this.name)
}
var o1 = new Person(1,11)
var o2 = new Person(2,22)
o1.friends.push('c')
console.log(o2.friends) // ['a', 'b', 'c']

構(gòu)造函數(shù)和原型模式組合

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
function Person(name, age) {
  this.name = name
  this.age = age
  this.friends = ['a']
}
Person.prototype = {
  constructor: Person,
  sayName: function() {
    console.log(this.name)
  }
}
var o1 = new Person(1,11)
var o2 = new Person(2,22)
o1.sayName() // 1
o2.sayName() // 2

優(yōu)點:每個實例有自己的屬性,同時又共享著方法的引用,還支持傳參數(shù)

動態(tài)原型模式

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
function Person(name, age) {
  this.name = name
  this.age = age
  this.friends = ['a']
  if(typeof this.sayName != 'function') {
    Person.prototype.sayName = function() {
      console.log(this.name)
    }
  }
}
var o1 = new Person(1,11)
var o2 = new Person(2,22)
o1.sayName() // 1
o2.sayName() // 2

優(yōu)點:僅在方法不存在的時候創(chuàng)建一次,避免重復(fù)創(chuàng)建

寄生構(gòu)造函數(shù)模式

?
1
2
3
4
5
6
7
8
9
10
11
12
function SpecialArray() {
  var o = new Array()
  // 添加值
  o.push.apply(o, arguments)
  // 添加方法
  o.toPipedString = function(){
    return this.join('|')
  }
  return o
}
var o1 = new SpecialArray(1,11)
o1.toPipedString() // 1|11

優(yōu)點:在不更改原始構(gòu)造函數(shù)的情況下為對象添加特殊方法
缺點:返回的對象與構(gòu)造函數(shù)以及構(gòu)造函數(shù)的原型沒有任何關(guān)系,該方法與在構(gòu)造函數(shù)外部創(chuàng)建的對象沒有什么不同

穩(wěn)妥構(gòu)造函數(shù)模式

?
1
2
3
4
5
6
7
8
9
10
function Person(name) {
  var o = new Object()
  // 添加方法
  o.getName = function(){
    return name
  }
  return o
}
var o1 = new Person(1)
o1.getName() // 1

與寄生構(gòu)造函數(shù)不同在于,不使用this,不使用new調(diào)用
優(yōu)點:除了使用getName外沒有任何方法能夠訪問name,在一些安全的環(huán)境使用
缺點:與工廠模式相似,無法識別對象所屬類型

以上就是js 創(chuàng)建對象的多種方式與優(yōu)缺點小結(jié)的詳細內(nèi)容,更多關(guān)于js 創(chuàng)建對象的資料請關(guān)注服務(wù)器之家其它相關(guān)文章!

原文鏈接:https://segmentfault.com/a/1190000039376338

延伸 · 閱讀

精彩推薦
  • js教程JavaScript 生成唯一ID的幾種方式

    JavaScript 生成唯一ID的幾種方式

    這篇文章主要介紹了JavaScript 生成唯一ID的幾種方式,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下...

    specialCoder5022022-01-21
  • js教程微信小程序抽獎組件的使用步驟

    微信小程序抽獎組件的使用步驟

    這篇文章主要給大家介紹了關(guān)于微信小程序抽獎組件的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需...

    い 狂奔的蝸牛10892021-12-29
  • js教程詳解如何愉快的在微信小程序中使用SVG圖標

    詳解如何愉快的在微信小程序中使用SVG圖標

    這篇文章主要介紹了詳解如何愉快的在微信小程序中使用SVG圖標,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要...

    O_o3252022-02-13
  • js教程JS實現(xiàn)簡單抖動效果

    JS實現(xiàn)簡單抖動效果

    這篇文章給大家結(jié)束了通過js實現(xiàn)抖動效果,非常不錯,具有參考借鑒價值,感興趣的朋友參考下吧...

    catEatBird9232022-01-12
  • js教程javascript中l(wèi)ayim之查找好友查找群組

    javascript中l(wèi)ayim之查找好友查找群組

    這篇文章主要介紹了javascript中l(wèi)ayim之查找好友查找群組,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下...

    踮腳敲代碼9182022-01-19
  • js教程JavaScript中l(wèi)ayim之整合右鍵菜單的示例代碼

    JavaScript中l(wèi)ayim之整合右鍵菜單的示例代碼

    這篇文章主要介紹了JavaScript中l(wèi)ayim之整合右鍵菜單的示例代碼,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以...

    踮腳敲代碼11522022-01-19
  • js教程js實現(xiàn)簡單放大鏡特效

    js實現(xiàn)簡單放大鏡特效

    這篇文章主要為大家詳細介紹了js實現(xiàn)簡單放大鏡特效,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    一個21歲的老同志9442022-02-13
  • js教程js實現(xiàn)電燈開關(guān)效果

    js實現(xiàn)電燈開關(guān)效果

    這篇文章主要為大家詳細介紹了js實現(xiàn)電燈開關(guān)效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    小蘇(o﹃o )7162022-01-04
主站蜘蛛池模板: 欧美日韩国产在线 | 久久亚洲一区二区三区四区 | 91精品国产综合久久久久久丝袜 | 欧美大片高清在线观看平台 | 免费观看黄视频 | 国产精品一区二区三区在线播放 | 99精品视频在线观看 | 亚洲精品www久久久久久广东 | 欧美a网站| 成人综合色区 | 凹凸日日摸日日碰夜夜爽孕妇 | 亚洲国产一区二区a毛片 | 视频一区在线 | 在线观看欧美日韩 | 精品一区二区三区免费毛片爱 | 国内外精品一区二区三区 | 999久久久国产999久久久 | 国产精品一区二区三区免费 | 高清国产一区二区三区 | 黄色一级毛片在线观看 | 激情欧美一区二区三区中文字幕 | 精品一区视频 | 精品九九久久 | 色屁屁影院 | 在线观看中文字幕亚洲 | 男人久久久 | 亚洲不卡在线观看 | 99久久久久久 | 精品性| 91人人网 | 久久精品视频网站 | 人人99 | 97视频精品| 色综合久久久久久久久久久 | 欧美视频在线观看 | 一区久久 | 国产精品a久久久久 | 欧美高清一区 | 国产乱叫456| 国产中文视频 | 性色网址|