160 lines
3.0 KiB
Markdown
160 lines
3.0 KiB
Markdown
---
|
||
id: 56bbb991ad1ed5201cd392d0
|
||
title: 创建 JavaScript 对象
|
||
challengeType: 1
|
||
videoUrl: 'https://scrimba.com/c/cWGkbtd'
|
||
forumTopicId: 16769
|
||
dashedName: build-javascript-objects
|
||
---
|
||
|
||
# --description--
|
||
|
||
你可能听说过对象(`object`)这个概念。
|
||
|
||
对象和数组很相似。区别在于,数组是通过索引来访问和修改数据,而对象是通过`属性`来访问和修改数据。
|
||
|
||
对象可以让存储的数据结构化,它可以让我们更好地描述真实世界的物体,比如一只猫。
|
||
|
||
这是一个对象的示例:
|
||
|
||
```js
|
||
var cat = {
|
||
"name": "Whiskers",
|
||
"legs": 4,
|
||
"tails": 1,
|
||
"enemies": ["Water", "Dogs"]
|
||
};
|
||
```
|
||
|
||
在这个示例中,属性都是以字符串的形式储存,例如 `"name"`、`"legs"`、`"tails"`。然而,我们也可以使用数字作为属性,甚至可以省略字符串属性的引号,如下所示:
|
||
|
||
```js
|
||
var anotherObject = {
|
||
make: "Ford",
|
||
5: "five",
|
||
"model": "focus"
|
||
};
|
||
```
|
||
|
||
但是,如果你的对象包含任何非字符串属性,JavaScript 也会将它们自动转换为字符串。
|
||
|
||
# --instructions--
|
||
|
||
请创建一个名为 `myDog` 的对象,它应包含这些属性:`"name"`、`"legs"`、`"tails"`、`"friends"`。
|
||
|
||
请确保 `"name"` 属性值是字符串、`"legs"` 和 `"tails"` 属性值是数字、`"friends"` 属性值是数组。只要满足这些条件,你可以随意设定这些属性值。
|
||
|
||
# --hints--
|
||
|
||
`myDog` 应包含 `name` 属性,且属性值是一个字符串。
|
||
|
||
```js
|
||
assert(
|
||
(function (z) {
|
||
if (
|
||
z.hasOwnProperty('name') &&
|
||
z.name !== undefined &&
|
||
typeof z.name === 'string'
|
||
) {
|
||
return true;
|
||
} else {
|
||
return false;
|
||
}
|
||
})(myDog)
|
||
);
|
||
```
|
||
|
||
`myDog` 应包含 `legs` 属性,且属性值是一个数字。
|
||
|
||
```js
|
||
assert(
|
||
(function (z) {
|
||
if (
|
||
z.hasOwnProperty('legs') &&
|
||
z.legs !== undefined &&
|
||
typeof z.legs === 'number'
|
||
) {
|
||
return true;
|
||
} else {
|
||
return false;
|
||
}
|
||
})(myDog)
|
||
);
|
||
```
|
||
|
||
`myDog` 应包含 `tails` 属性,且属性值是一个数字。
|
||
|
||
```js
|
||
assert(
|
||
(function (z) {
|
||
if (
|
||
z.hasOwnProperty('tails') &&
|
||
z.tails !== undefined &&
|
||
typeof z.tails === 'number'
|
||
) {
|
||
return true;
|
||
} else {
|
||
return false;
|
||
}
|
||
})(myDog)
|
||
);
|
||
```
|
||
|
||
`myDog` 应包含 `friends` 属性,且属性值是一个数组。
|
||
|
||
```js
|
||
assert(
|
||
(function (z) {
|
||
if (
|
||
z.hasOwnProperty('friends') &&
|
||
z.friends !== undefined &&
|
||
Array.isArray(z.friends)
|
||
) {
|
||
return true;
|
||
} else {
|
||
return false;
|
||
}
|
||
})(myDog)
|
||
);
|
||
```
|
||
|
||
`myDog` 应只包含给定的属性。
|
||
|
||
```js
|
||
assert(
|
||
(function (z) {
|
||
return Object.keys(z).length === 4;
|
||
})(myDog)
|
||
);
|
||
```
|
||
|
||
# --seed--
|
||
|
||
## --after-user-code--
|
||
|
||
```js
|
||
(function(z){return z;})(myDog);
|
||
```
|
||
|
||
## --seed-contents--
|
||
|
||
```js
|
||
var myDog = {
|
||
// Only change code below this line
|
||
|
||
|
||
// Only change code above this line
|
||
};
|
||
```
|
||
|
||
# --solutions--
|
||
|
||
```js
|
||
var myDog = {
|
||
"name": "Camper",
|
||
"legs": 4,
|
||
"tails": 1,
|
||
"friends": ["everything!"]
|
||
};
|
||
```
|