偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

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

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

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

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

[[332311]]

對象字面量

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

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

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

  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 

簡寫屬性名稱

假設(shè)必須將不同的變量放在一個對象內(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,可通過較短的表示法實現(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)建對象。仔細想,其實它們本身已經(jīng)是對象了,因此對象用于創(chuàng)建更多對象。

通常,此方法優(yōu)于對象構(gòu)造函數(shù)。試想必須創(chuàng)建數(shù)百個具有相同屬性的對象,使用對象構(gòu)造函數(shù)方法,必須手動將所有屬性添加到所有對象,但是使用構(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ù)量的對象。

重復(fù)的屬性名稱

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

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

New關(guān)鍵字

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

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

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

下一步是向此空對象添加屬性和方法,可通過簡單的點標記來實現(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 

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

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

此方法與通過用戶定義的構(gòu)造函數(shù)使用new關(guān)鍵字非常類似。類是面向?qū)ο缶幊?OOP)的主要組件,可以創(chuàng)建實際上是對象的許多類實例。在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)建實例中,成為“對象”:

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

你掌握了嗎?

 

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

2020-09-26 21:57:44

python變量開發(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ù)中心邊緣計算網(wǎng)絡(luò)

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

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

2023-11-21 15:23:15

JavaScript工具

2018-12-19 19:30:46

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

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?關(guān)鍵字C#

2020-04-08 12:50:29

Python編程語言開發(fā)

2024-01-01 16:01:22

Python函數(shù)

2020-06-12 08:28:29

JavaScript開發(fā)技術(shù)
點贊
收藏

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