freeCodeCamp/curriculum/challenges/chinese-traditional/02-javascript-algorithms-an.../basic-data-structures/check-if-an-object-has-a-pr...

3.0 KiB
Raw Blame History

id title challengeType forumTopicId dashedName
587d7b7d367417b2b2512b1c 檢查對象是否具有某個屬性 1 301155 check-if-an-object-has-a-property

--description--

我們已經學習瞭如何添加、修改和移除對象中的屬性。 但如果我們想知道一個對象中是否包含某個屬性呢? JavaScript 爲我們提供了兩種不同的方式來實現這個功能: 一個是通過 hasOwnProperty() 方法,另一個是使用 in 關鍵字。 假如我們有一個 users 對象,爲檢查它是否含有 Alan 屬性,可以這樣寫:

users.hasOwnProperty('Alan');
'Alan' in users;

這兩者結果都應該爲 true

--instructions--

請完善這個函數,如果傳遞給它的對象包含四個名字 AlanJeffSarahRyan,函數返回 true否則返回 false。

--hints--

不應直接訪問 users 對象。


assert(code.match(/users/gm).length <= 2)

users 對象應該只包含 AlanJeffSarahRyan 4 個鍵。

assert(
  'Alan' in users &&
    'Jeff' in users &&
    'Sarah' in users &&
    'Ryan' in users &&
    Object.keys(users).length === 4
);

如果 AlanJeffSarahRyan 是傳遞給函數 isEveryoneHere 對象的屬性,則函數應返回 true

assert(isEveryoneHere(users) === true);

如果傳遞給函數 isEveryoneHere 對象的屬性中不包含 Alan,則函數返回 false

assert(
  (function () {
    delete users.Alan;
    return isEveryoneHere(users);
  })() === false
);

如果傳遞給函數 isEveryoneHere 對象的屬性中不包含 Jeff,則函數返回 false

assert(
  (function () {
    delete users.Jeff;
    return isEveryoneHere(users);
  })() === false
);

如果傳遞給函數 isEveryoneHere 對象的屬性中不包含 Sarah,則函數返回 false

assert(
  (function () {
    delete users.Sarah;
    return isEveryoneHere(users);
  })() === false
);

如果傳遞給函數 isEveryoneHere 對象的屬性中不包含 Ryan,則函數返回 false

assert(
  (function () {
    delete users.Ryan;
    return isEveryoneHere(users);
  })() === false
);

--seed--

--seed-contents--

let users = {
  Alan: {
    age: 27,
    online: true
  },
  Jeff: {
    age: 32,
    online: true
  },
  Sarah: {
    age: 48,
    online: true
  },
  Ryan: {
    age: 19,
    online: true
  }
};

function isEveryoneHere(userObj) {
  // Only change code below this line

  // Only change code above this line
}

console.log(isEveryoneHere(users));

--solutions--

let users = {
  Alan: {
    age: 27,
    online: true
  },
  Jeff: {
    age: 32,
    online: true
  },
  Sarah: {
    age: 48,
    online: true
  },
  Ryan: {
    age: 19,
    online: true
  }
};

function isEveryoneHere(userObj) {
  return [
    'Alan',
    'Jeff',
    'Sarah',
    'Ryan'
  ].every(user => userObj.hasOwnProperty(user));
}

console.log(isEveryoneHere(users));