180 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			180 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| id: 56533eb9ac21ba0edf2244cb
 | |
| title: 操作複雜對象
 | |
| challengeType: 1
 | |
| videoUrl: 'https://scrimba.com/c/c9yNMfR'
 | |
| forumTopicId: 18208
 | |
| dashedName: manipulating-complex-objects
 | |
| ---
 | |
| 
 | |
| # --description--
 | |
| 
 | |
| 有時你可能希望將數據存儲在一個靈活的數據結構(<dfn>Data Structure</dfn>)中。 JavaScript 對象是一種靈活的數據結構。 它可以儲存字符串(<dfn>strings</dfn>)、數字(<dfn>numbers</dfn>)、布爾值(<dfn>booleans</dfn>)、數組(<dfn>arrays</dfn>)、函數(<dfn>functions</dfn>)和對象(<dfn>objects</dfn>)以及這些值的任意組合。
 | |
| 
 | |
| 這是一個複雜數據結構的示例:
 | |
| 
 | |
| ```js
 | |
| var ourMusic = [
 | |
|   {
 | |
|     "artist": "Daft Punk",
 | |
|     "title": "Homework",
 | |
|     "release_year": 1997,
 | |
|     "formats": [ 
 | |
|       "CD", 
 | |
|       "Cassette", 
 | |
|       "LP"
 | |
|     ],
 | |
|     "gold": true
 | |
|   }
 | |
| ];
 | |
| ```
 | |
| 
 | |
| 這是一個包含一個對象的數組。 該對象有關於專輯的各種元數據(<dfn>metadata</dfn>)。 它也有一個嵌套的 `formats` 數組。 可以將專輯添加到頂級數組來增加更多的專輯記錄。 對象將數據以一種鍵 - 值對的形式保存。 在上面的示例中,`"artist": "Daft Punk"` 有一個鍵位 `artist` 值爲 `Daft Punk` 的屬性。 [JavaScript Object Notation](http://www.json.org/) 簡稱 `JSON` 是可以用於存儲數據的數據交換格式。
 | |
| 
 | |
| ```json
 | |
| {
 | |
|   "artist": "Daft Punk",
 | |
|   "title": "Homework",
 | |
|   "release_year": 1997,
 | |
|   "formats": [ 
 | |
|     "CD",
 | |
|     "Cassette",
 | |
|     "LP"
 | |
|   ],
 | |
|   "gold": true
 | |
| }
 | |
| ```
 | |
| 
 | |
| **提示:**數組中有多個 JSON 對象的時候,對象與對象之間要用逗號隔開。
 | |
| 
 | |
| # --instructions--
 | |
| 
 | |
| 添加一個新專輯到 `myMusic` 數組。 添加 `artist` 和 `title` 字符串,`release_year` 數字和 `formats` 字符串數組。
 | |
| 
 | |
| # --hints--
 | |
| 
 | |
| `myMusic` 應該是一個數組
 | |
| 
 | |
| ```js
 | |
| assert(Array.isArray(myMusic));
 | |
| ```
 | |
| 
 | |
| `myMusic`應該有至少2個元素。
 | |
| 
 | |
| ```js
 | |
| assert(myMusic.length > 1);
 | |
| ```
 | |
| 
 | |
| `myMusic`元素數組中應該是物體
 | |
| 
 | |
| ```js
 | |
| myMusic.forEach(object => {assert.typeOf(object, 'object')})
 | |
| ```
 | |
| 
 | |
| `myMusic` 中的對象應該至少有 4 個屬性。
 | |
| 
 | |
| ```js
 | |
| myMusic.forEach(object => {assert(Object.keys(object).length > 3); });
 | |
| ```
 | |
| 
 | |
| `myMusic` 中的對象應該包含一個類型爲字符串的屬性 `artist`。
 | |
| 
 | |
| ```js
 | |
| myMusic.forEach(object => {
 | |
|   assert.containsAllKeys(object, ['artist']);
 | |
|   assert.typeOf(object.artist, 'string')
 | |
| })
 | |
| ```
 | |
| 
 | |
| `myMusic` 中的對象應該包含一個類型爲字符串的屬性 `title`。
 | |
| 
 | |
| ```js
 | |
| myMusic.forEach(object => {
 | |
|   assert.containsAllKeys(object, ['title']);
 | |
|   assert.typeOf(object.title, 'string')
 | |
| })
 | |
| ```
 | |
| 
 | |
| `myMusic` 中的對象應該包含一個類型爲數字的屬性 `release_year`。
 | |
| 
 | |
| ```js
 | |
| myMusic.forEach(object => {
 | |
|   assert.containsAllKeys(object, ['release_year']);
 | |
|   assert.typeOf(object.release_year, 'number')
 | |
| })
 | |
| ```
 | |
| 
 | |
| `myMusic` 中的對象應該包含一個類型爲數組的 `formats` 屬性。
 | |
| 
 | |
| ```js
 | |
| myMusic.forEach(object => {
 | |
|   assert.containsAllKeys(object, ['formats']);
 | |
|   assert.typeOf(object.formats, 'array')
 | |
| })
 | |
| ```
 | |
| 
 | |
| `formats`應該是一個至少包含兩個字符串元素的數組
 | |
| 
 | |
| ```js
 | |
| myMusic.forEach(object => {
 | |
|   object.formats.forEach(format => {
 | |
|     assert.typeOf(format, 'string')
 | |
|   });
 | |
|   assert.isAtLeast(object.formats.length, 2)
 | |
| })
 | |
| ```
 | |
| 
 | |
| # --seed--
 | |
| 
 | |
| ## --after-user-code--
 | |
| 
 | |
| ```js
 | |
| (function(x){ if (Array.isArray(x)) { return JSON.stringify(x); } return "myMusic is not an array"})(myMusic);
 | |
| ```
 | |
| 
 | |
| ## --seed-contents--
 | |
| 
 | |
| ```js
 | |
| var myMusic = [
 | |
|   {
 | |
|     "artist": "Billy Joel",
 | |
|     "title": "Piano Man",
 | |
|     "release_year": 1973,
 | |
|     "formats": [
 | |
|       "CD",
 | |
|       "8T",
 | |
|       "LP"
 | |
|     ],
 | |
|     "gold": true
 | |
|   }
 | |
| ];
 | |
| ```
 | |
| 
 | |
| # --solutions--
 | |
| 
 | |
| ```js
 | |
| var myMusic = [
 | |
|   {
 | |
|     "artist": "Billy Joel",
 | |
|     "title": "Piano Man",
 | |
|     "release_year": 1973,
 | |
|     "formats": [
 | |
|       "CS",
 | |
|       "8T",
 | |
|       "LP" ],
 | |
|     "gold": true
 | |
|   },
 | |
|   {
 | |
|     "artist": "ABBA",
 | |
|     "title": "Ring Ring",
 | |
|     "release_year": 1973,
 | |
|     "formats": [
 | |
|       "CS",
 | |
|       "8T",
 | |
|       "LP",
 | |
|     "CD",
 | |
|   ]
 | |
|   }
 | |
| ];
 | |
| ```
 |