成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JavaScript中幾乎一切都是對象:創建對象的三種方式

開發 前端
Javascript中的一切幾乎都是對象,無論是數組還是函數。本文將教你使用JavaScript創建對象的三種方法。

本文轉載自公眾號“讀芯術”(ID:AI_Discovery)。

Javascript中的一切幾乎都是對象,無論是數組還是函數。本文將教你使用JavaScript創建對象的三種方法。

[[332311]]

對象字面量

JavaScript對象字面量是指用大括號括起來的用逗號分隔的名稱——值對列表。對象字面量用于封裝代碼并將其包裝在有序的包中。

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

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

  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 

簡寫屬性名稱

假設必須將不同的變量放在一個對象內,有一種方法是:

  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,可通過較短的表示法實現相同的目的:

  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 

用戶定義的構造函數

你也可以使用函數在JavaScript中創建對象。仔細想,其實它們本身已經是對象了,因此對象用于創建更多對象。

通常,此方法優于對象構造函數。試想必須創建數百個具有相同屬性的對象,使用對象構造函數方法,必須手動將所有屬性添加到所有對象,但是使用構造函數可以預定義這些屬性。

  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. // } 

使用相同的構造函數,可以創建任意數量的對象。

重復的屬性名稱

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

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

New關鍵字

對象構造函數為給定值創建一個對象封裝器。如果該值不存在或未定義,它將創建并返回至一個空對象。否則的話,它將返回至一個與給定值類型一致的對象。

也可以使用new關鍵字創建對象。使用Javascript中的內置對象構造函數,創建一個新的空對象;或者,此關鍵字可以與用戶定義的構造函數一起使用。首先來看一個例子:

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

下一步是向此空對象添加屬性和方法,可通過簡單的點標記來實現:

  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 

但我不建議這種做法,因為后臺有作用域解析,可以檢查構造函數是內置的還是用戶定義的。

使用ES6類創建對象

此方法與通過用戶定義的構造函數使用new關鍵字非常類似。類是面向對象編程(OOP)的主要組件,可以創建實際上是對象的許多類實例。在ES6規范的支持下,現在可以用類替換構造函數。

  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 

上面示例中,我已經定義了構造函數中的所有參數。方法可以是類的一部分,而聲明可以稍后添加到類的創建實例中,成為“對象”:

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

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

[[332312]]

圖源:unsplash

在JavaScript這一基于原型的繼承語言中,類和構造函數都模仿面向對象的繼承模型。熟悉類非常有幫助,React這樣的流行JavaScript庫會經常使用類句法。

你掌握了嗎?

 

責任編輯:趙寧寧 來源: 今日頭條
相關推薦

2020-09-26 21:57:44

python變量開發

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

數據中心邊緣計算網絡

2018-06-21 11:27:06

Windows 7更新停止

2017-06-14 16:44:15

JavaScript原型模式對象

2020-04-02 10:08:21

分布式外星人平臺

2020-03-31 16:30:09

JS語言ES 6

2020-10-14 08:04:28

JavaScrip

2019-08-01 07:56:43

安全數據網絡安全安全分析

2023-11-21 15:23:15

JavaScript工具

2018-12-19 19:30:46

JavaScript創建對象前端

2023-09-07 15:11:44

2009-09-25 15:58:04

Hibernate對象

2023-12-19 16:43:01

2024-12-31 00:05:24

new?關鍵字C#

2024-01-01 16:01:22

Python函數

2020-04-08 12:50:29

Python編程語言開發

2013-08-08 10:20:39

大數據
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 中文字幕免费在线 | 欧美精品在线看 | 欧美综合久久久 | 欧美一级免费看 | 激情五月激情综合网 | 国产成人久久精品一区二区三区 | 亚洲永久免费观看 | 欧美日韩亚洲一区 | 黄色网址在线免费播放 | 中文字幕不卡在线观看 | 精国产品一区二区三区 | 国产日韩欧美一区二区在线播放 | 日韩av成人在线 | 国产精品久久久久久 | 日韩在线精品强乱中文字幕 | 久久一区二区视频 | 久久久亚洲 | 51ⅴ精品国产91久久久久久 | 国产高清久久 | 午夜精品久久久 | 国产精品国产 | av首页在线| 久久久妇女国产精品影视 | 国产日韩久久 | 毛片软件| 亚洲一二三区精品 | 亚洲av毛片 | 成人午夜免费福利视频 | 日韩欧美视频 | 久久国产免费 | 国产精品自拍视频 | 91色综合 | 日韩 国产 在线 | 性一交一乱一透一a级 | 国产成人免费视频网站高清观看视频 | 超碰综合| 久久亚洲二区 | 国产福利91精品一区二区三区 | 日韩精品在线免费观看视频 | 国产一级电影在线观看 | 欧美日本韩国一区二区 |