自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

JavaScript中幾乎一切都是對(duì)象:創(chuàng)建對(duì)象的三種方式

開(kāi)發(fā) 前端
Javascript中的一切幾乎都是對(duì)象,無(wú)論是數(shù)組還是函數(shù)。本文將教你使用JavaScript創(chuàng)建對(duì)象的三種方法。

本文轉(zhuǎn)載自公眾號(hào)“讀芯術(shù)”(ID:AI_Discovery)。

Javascript中的一切幾乎都是對(duì)象,無(wú)論是數(shù)組還是函數(shù)。本文將教你使用JavaScript創(chuàng)建對(duì)象的三種方法。

[[332311]]

對(duì)象字面量

JavaScript對(duì)象字面量是指用大括號(hào)括起來(lái)的用逗號(hào)分隔的名稱——值對(duì)列表。對(duì)象字面量用于封裝代碼并將其包裝在有序的包中。

  1. let Person = { 
  2.   name: "Foziya", 
  3.   age: 20, 
  4.   action: ["walk", " run"], 
  5.   greeting: function() { 
  6.     console.log("Hello"); 
  7.   } 
  8. }; 

對(duì)象字面量的屬性值可以是任何數(shù)據(jù)類型,包括數(shù)組字面量、函數(shù)字面量和嵌套對(duì)象字面量。

  1. let shape = { 
  2.   name: "rectangle", 
  3.   color: "red", 
  4.   size: { 
  5.     length: 10, 
  6.     breadth: 20 
  7.   } 
  8. }; 
  9.   
  10. console.log(shape); 
  11.  // { name:'rectangle', 
  12.  // color: 'red', 
  13.  // size: { length:10, breadth: 20 } } 
  14.   
  15. console.log(shape.size.length) 
  16. // 10 

簡(jiǎn)寫屬性名稱

假設(shè)必須將不同的變量放在一個(gè)對(duì)象內(nèi),有一種方法是:

  1. let one = 1
  2. let two = 2
  3. let three = 3
  4.   
  5. let numbers = { 
  6.   one: one, 
  7.   two: two, 
  8.   three: three 
  9. }; 
  10. console.log(numbers); 
  11.   
  12. //{ one: 1, two: 2, three: 3 } 

使用ECMAScript 2015,可通過(guò)較短的表示法實(shí)現(xiàn)相同的目的:

  1. let one = 1
  2. let two = 2
  3. let three = 3
  4.   
  5. let numbers = { one, two, three }; 
  6.   
  7. console.log(numbers); 
  8. //{ one: 1, two: 2, three: 3 } 
  9.   
  10. console.log(numbers.one) 
  11. // 1 
  12.   
  13. console.log(numbers.one === { one }.one); 
  14. // true 

用戶定義的構(gòu)造函數(shù)

你也可以使用函數(shù)在JavaScript中創(chuàng)建對(duì)象。仔細(xì)想,其實(shí)它們本身已經(jīng)是對(duì)象了,因此對(duì)象用于創(chuàng)建更多對(duì)象。

通常,此方法優(yōu)于對(duì)象構(gòu)造函數(shù)。試想必須創(chuàng)建數(shù)百個(gè)具有相同屬性的對(duì)象,使用對(duì)象構(gòu)造函數(shù)方法,必須手動(dòng)將所有屬性添加到所有對(duì)象,但是使用構(gòu)造函數(shù)可以預(yù)定義這些屬性。

  1. functionmovies(name, releaseYear, genre, ratings) { 
  2.   this.name = name; 
  3.   this.releaseYear =releaseYear; 
  4.   this.genre = genre; 
  5.   this.ratings =ratings; 
  6.   this.watch = () => { 
  7.     console.log("WatchOnline"); 
  8.   }; 
  9.   
  10. let DPS = new movies("Dead Poets Society", 1989, ["Drama", "Teen"], { 
  11.   IMDb: "8.1 /10", 
  12.   Metacritic: "79%" 
  13. }); 
  14.   
  15. console.log(DPS);movies { 
  16. //     name: 'Dead Poets Society', 
  17. //         releaseYear: 1989, 
  18. //             genre: ['Drama','Teen'], 
  19. //                 ratings: { IMDb:'8.1 / 10', Metacritic: '79%' }, 
  20. //     watch: [Function] 
  21. // } 
  22.   
  23.   
  24. let rocky = new movies("Rocky", 1976, ["Drama", "Sports"], { 
  25.   IMDb: "8.1 /10", 
  26.   Metacritic: "70%" 
  27. }); 
  28.   
  29. console.log(rocky); 
  30.   
  31. // movies { 
  32. //     name: 'Rocky', 
  33. //         releaseYear: 1976, 
  34. //             genre: ['Drama','Sports'], 
  35. //                 ratings: { IMDb:'8.1 / 10', Metacritic: '70%' }, 
  36. //     watch: [Function] 
  37. // } 

使用相同的構(gòu)造函數(shù),可以創(chuàng)建任意數(shù)量的對(duì)象。

重復(fù)的屬性名稱

如果兩個(gè)屬性使用相同的名稱,則第二個(gè)屬性將覆蓋第一個(gè)屬性。

  1. let Person = { 
  2.   name: "NeyVatsa", 
  3.   name: "Shashank" 
  4. }; 
  5. console.log(Person.name); 
  6.   
  7. // Shashank 

New關(guān)鍵字

對(duì)象構(gòu)造函數(shù)為給定值創(chuàng)建一個(gè)對(duì)象封裝器。如果該值不存在或未定義,它將創(chuàng)建并返回至一個(gè)空對(duì)象。否則的話,它將返回至一個(gè)與給定值類型一致的對(duì)象。

也可以使用new關(guān)鍵字創(chuàng)建對(duì)象。使用Javascript中的內(nèi)置對(duì)象構(gòu)造函數(shù),創(chuàng)建一個(gè)新的空對(duì)象;或者,此關(guān)鍵字可以與用戶定義的構(gòu)造函數(shù)一起使用。首先來(lái)看一個(gè)例子:

  1. let movies = newObject(); 
  2.   
  3. console.log(movies) 
  4. //{} 

下一步是向此空對(duì)象添加屬性和方法,可通過(guò)簡(jiǎn)單的點(diǎn)標(biāo)記來(lái)實(shí)現(xiàn):

  1. let movies = newObject(); 
  2.   
  3. console.log(movies) 
  4. //{} 
  5.   
  6. movies.name = "Dead Poets Society"
  7. movies.releaseYear = 1989
  8. movies.genre = ["Drama", "Teen"]; 
  9. movies.ratings = { 
  10.   IMDb: "8.1 /10", 
  11.   Metacritic: "79%" 
  12. }; 
  13. movies.watch = () => { 
  14.   console.log("WatchOnline"); 
  15. }; 
  16.   
  17. console.log(movies); 
  18. // { name: 'Dead Poets Society', 
  19. //  releaseYear: 1989, 
  20. //  genre: [ 'Drama', 'Teen' ], 
  21. //  ratings: { IMDb: '8.1 / 10',Metacritic: '79%' }, 
  22. //  watch: [Function] } 
  23.   
  24. movies.watch(); 
  25. // Watch Online 

但我不建議這種做法,因?yàn)楹笈_(tái)有作用域解析,可以檢查構(gòu)造函數(shù)是內(nèi)置的還是用戶定義的。

使用ES6類創(chuàng)建對(duì)象

此方法與通過(guò)用戶定義的構(gòu)造函數(shù)使用new關(guān)鍵字非常類似。類是面向?qū)ο缶幊?OOP)的主要組件,可以創(chuàng)建實(shí)際上是對(duì)象的許多類實(shí)例。在ES6規(guī)范的支持下,現(xiàn)在可以用類替換構(gòu)造函數(shù)。

  1. classMovies { 
  2.   constructor(name,releaseYear, genre, ratings) { 
  3.     this.name = name; 
  4.     this.releaseYear = releaseYear; 
  5.     this.genre = genre; 
  6.     this.ratings =ratings; 
  7.   } 
  8.   watch() { 
  9.     console.log("WatchOnline"); 
  10.   } 
  11. let rocky = new Movies("Rocky", 1976, ["Drama", "Sports"], { 
  12.   IMDb: "8.1 /10", 
  13.   Metacritic: "70%" 
  14. }); 
  15. console.log(rocky); 
  16. // Movies { 
  17. //     name: 'Rocky', 
  18. //         releaseYear: 1976, 
  19. //             genre: ['Drama','Sports'], 
  20. //                 ratings: { IMDb:'8.1 / 10', Metacritic: '70%' } 
  21. // } 
  22.   
  23. rocky.watch(); 
  24. //Watch Online 

上面示例中,我已經(jīng)定義了構(gòu)造函數(shù)中的所有參數(shù)。方法可以是類的一部分,而聲明可以稍后添加到類的創(chuàng)建實(shí)例中,成為“對(duì)象”:

  1. /* 
  2. above example 
  3. */ 
  4. rocky.buy = function() { 
  5.   console.log("Buy theMovie"); 
  6. }; 
  7. rocky.buy(); 
  8. // Buy the Movie 

而這里方法是對(duì)象的一部分,不會(huì)影響原始類。

[[332312]]

圖源:unsplash

在JavaScript這一基于原型的繼承語(yǔ)言中,類和構(gòu)造函數(shù)都模仿面向?qū)ο蟮睦^承模型。熟悉類非常有幫助,React這樣的流行JavaScript庫(kù)會(huì)經(jīng)常使用類句法。

你掌握了嗎?

 

責(zé)任編輯:趙寧寧 來(lái)源: 今日頭條
相關(guān)推薦

2020-09-26 21:57:44

python變量開(kāi)發(fā)

2021-03-23 09:35:23

Inode文件Linux

2015-08-18 14:00:55

容器DockerDevOps

2016-08-12 09:04:37

Linux文件類型目錄

2018-06-28 22:41:55

數(shù)據(jù)中心邊緣計(jì)算網(wǎng)絡(luò)

2018-06-21 11:27:06

Windows 7更新停止

2017-06-14 16:44:15

JavaScript原型模式對(duì)象

2020-04-02 10:08:21

分布式外星人平臺(tái)

2020-03-31 16:30:09

JS語(yǔ)言ES 6

2020-10-14 08:04:28

JavaScrip

2023-11-21 15:23:15

JavaScript工具

2019-08-01 07:56:43

安全數(shù)據(jù)網(wǎng)絡(luò)安全安全分析

2018-12-19 19:30:46

JavaScript創(chuàng)建對(duì)象前端

2009-09-25 15:58:04

Hibernate對(duì)象

2024-12-31 00:05:24

new?關(guān)鍵字C#

2023-12-19 16:43:01

2023-09-07 15:11:44

2024-01-01 16:01:22

Python函數(shù)

2020-06-12 08:28:29

JavaScript開(kāi)發(fā)技術(shù)

2020-04-08 12:50:29

Python編程語(yǔ)言開(kāi)發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)