freeCodeCamp/curriculum/challenges/chinese/02-javascript-algorithms-an.../intermediate-algorithm-scri.../everything-be-true.md

138 lines
3.6 KiB
Markdown
Raw Normal View History

---
id: a10d2431ad0c6a099a4b8b52
title: 检查对象属性
challengeType: 5
forumTopicId: 16011
---
# --description--
对于第一个参数(对象数组)中的每个元素,检查第二个参数(字符串)所对应的属性值是否都为 <dfn>truthy</dfn>
换句话说,函数的第一个参数是一个对象数组,第二个参数是一个字符串 `pre`,表示对象的属性。如果数组中的每个对象里,`pre` 对应属性值均为 `truthy`,则返回 `true`;否则返回 `false`
JavaScript 中,如果一个值在 Boolean 的上下文中(比如 `if` 语句)的执行结果为 `true`,那么我们称这个值是 `truthy` 的。
别忘了,你可以使用点号表示法(`.`)或方括号表示法(`[]`)来访问对象的属性。
# --hints--
`truthCheck([{"user": "Tinky-Winky", "sex": "male"}, {"user": "Dipsy", "sex": "male"}, {"user": "Laa-Laa", "sex": "female"}, {"user": "Po", "sex": "female"}], "sex")` 应返回 true。
```js
assert.strictEqual(
truthCheck(
[
{ user: 'Tinky-Winky', sex: 'male' },
{ user: 'Dipsy', sex: 'male' },
{ user: 'Laa-Laa', sex: 'female' },
{ user: 'Po', sex: 'female' }
],
'sex'
),
true
);
```
`truthCheck([{"user": "Tinky-Winky", "sex": "male"}, {"user": "Dipsy"}, {"user": "Laa-Laa", "sex": "female"}, {"user": "Po", "sex": "female"}], "sex")` 应返回 false。
```js
assert.strictEqual(
truthCheck(
[
{ user: 'Tinky-Winky', sex: 'male' },
{ user: 'Dipsy' },
{ user: 'Laa-Laa', sex: 'female' },
{ user: 'Po', sex: 'female' }
],
'sex'
),
false
);
```
`truthCheck([{"user": "Tinky-Winky", "sex": "male", "age": 0}, {"user": "Dipsy", "sex": "male", "age": 3}, {"user": "Laa-Laa", "sex": "female", "age": 5}, {"user": "Po", "sex": "female", "age": 4}], "age")` 应返回 false。
```js
assert.strictEqual(
truthCheck(
[
{ user: 'Tinky-Winky', sex: 'male', age: 2 },
{ user: 'Dipsy', sex: 'male', age: 0 },
{ user: 'Laa-Laa', sex: 'female', age: 5 },
{ user: 'Po', sex: 'female', age: 4 }
],
'age'
),
false
);
```
`truthCheck([{"name": "Pete", "onBoat": true}, {"name": "Repeat", "onBoat": true}, {"name": "FastForward", "onBoat": null}], "onBoat")` 应返回 false。
```js
assert.strictEqual(
truthCheck(
[
{ name: 'Pete', onBoat: true },
{ name: 'Repeat', onBoat: true },
{ name: 'FastForward', onBoat: null }
],
'onBoat'
),
false
);
```
`truthCheck([{"name": "Pete", "onBoat": true}, {"name": "Repeat", "onBoat": true, "alias": "Repete"}, {"name": "FastForward", "onBoat": true}], "onBoat")` 应返回 true。
```js
assert.strictEqual(
truthCheck(
[
{ name: 'Pete', onBoat: true },
{ name: 'Repeat', onBoat: true, alias: 'Repete' },
{ name: 'FastForward', onBoat: true }
],
'onBoat'
),
true
);
```
`truthCheck([{"single": "yes"}], "single")` 应返回 true。
```js
assert.strictEqual(truthCheck([{ single: 'yes' }], 'single'), true);
```
`truthCheck([{"single": ""}, {"single": "double"}], "single")` 应返回 false。
```js
assert.strictEqual(
truthCheck([{ single: '' }, { single: 'double' }], 'single'),
false
);
```
`truthCheck([{"single": "double"}, {"single": undefined}], "single")` 应返回 false。
```js
assert.strictEqual(
truthCheck([{ single: 'double' }, { single: undefined }], 'single'),
false
);
```
`truthCheck([{"single": "double"}, {"single": NaN}], "single")` 应返回 false。
```js
assert.strictEqual(
truthCheck([{ single: 'double' }, { single: NaN }], 'single'),
false
);
```
# --solutions--