一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

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

服務器之家 - 編程語言 - JavaScript - js教程 - js 創建對象的多種方式與優缺點小結

js 創建對象的多種方式與優缺點小結

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

這篇文章主要介紹了js 創建對象的多種方式與優缺點,幫助大家更好的理解和學習使用JavaScript,感興趣的朋友可以了解下

早期創建方式

?
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: () => {}
}

缺點:使用同一個接口創建很多對象,會產生大量重復代碼

工廠模式

?
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)

優點:解決了創建多個相似對象代碼重復問題
缺點:無法識別對象是什么類型

構造函數模式

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

?
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

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

構造函數模式優化

?
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

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

原型模式

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

?
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

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

?
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']

構造函數和原型模式組合

?
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

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

動態原型模式

?
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

優點:僅在方法不存在的時候創建一次,避免重復創建

寄生構造函數模式

?
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

優點:在不更改原始構造函數的情況下為對象添加特殊方法
缺點:返回的對象與構造函數以及構造函數的原型沒有任何關系,該方法與在構造函數外部創建的對象沒有什么不同

穩妥構造函數模式

?
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

與寄生構造函數不同在于,不使用this,不使用new調用
優點:除了使用getName外沒有任何方法能夠訪問name,在一些安全的環境使用
缺點:與工廠模式相似,無法識別對象所屬類型

以上就是js 創建對象的多種方式與優缺點小結的詳細內容,更多關于js 創建對象的資料請關注服務器之家其它相關文章!

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

延伸 · 閱讀

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

    JavaScript 生成唯一ID的幾種方式

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

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

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

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

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

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

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

    O_o3252022-02-13
  • js教程JS實現簡單抖動效果

    JS實現簡單抖動效果

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

    catEatBird9232022-01-12
  • js教程javascript中layim之查找好友查找群組

    javascript中layim之查找好友查找群組

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

    踮腳敲代碼9182022-01-19
  • js教程JavaScript中layim之整合右鍵菜單的示例代碼

    JavaScript中layim之整合右鍵菜單的示例代碼

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

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

    js實現簡單放大鏡特效

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

    一個21歲的老同志9442022-02-13
  • js教程js實現電燈開關效果

    js實現電燈開關效果

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

    小蘇(o﹃o )7162022-01-04
主站蜘蛛池模板: 久久88综合 | 免费永久观看美女视频网站网址 | 超级毛片| 91av免费| 激情影院免费 | 日本四虎影视 | 九九热这里只有精品2 | yy3341殇情影院理论片 | 草草影院在线 | 扒开放荡老师裙子猛烈的进入 | 男女男精品视频免费观看 | 好姑娘在线完整版视频 | 深夜在线观看网站 | 亚洲第一男人天堂 | 四虎影院在线免费观看 | 青青在线国产视频 | 国产盗摄女厕美女嘘嘘 | 欧美日韩精品亚洲精品v18 | 精品国产在天天线在线麻豆 | 色多多视频网站 | 77成人影视| 4444kk在线看片| 97导航| 国产精品成人扳一级aa毛片 | 亚洲冬月枫中文字幕在线看 | 日本精品一区二区在线播放 | 亚洲欧美日韩综合在线 | 国产成+人+综合+亚洲欧美丁香花 | 色综合天天综合网国产人 | 青青国产成人久久激情91麻豆 | 免费国产一级观看完整版 | 无限好资源第一片免费韩国 | 秋霞在线一级 | 免费观看小视频 | 美女脱了内裤打开腿让你桶爽 | 大香焦在线 | 天堂中文在线观看 | 黑人巨摘花第一次出血 | 美女用屁股把人吞进肚子 | 国产区成人精品视频 | 日本中文字幕黑人借宿影片 |