freeCodeCamp/curriculum/challenges/chinese/02-javascript-algorithms-an.../object-oriented-programming/understand-own-properties.md

1.5 KiB
Raw Blame History

id title challengeType forumTopicId
587d7dae367417b2b2512b7b 了解自己的属性 1 301326

--description--

请看下面的实例,Bird构造函数定义了两个属性:namenumLegs

function Bird(name) {
  this.name  = name;
  this.numLegs = 2;
}

let duck = new Bird("Donald");
let canary = new Bird("Tweety");

namenumLegs被叫做自身属性,因为他们是直接在实例对象上定义的。这就意味着duckcanary这两个对象分别拥有这些属性的独立副本。 事实上,Bird的这些实例都将拥有这些属性的独立副本。 以下的代码将duck里面所有的自身属性都存到一个叫ownProps的数组里面:

let ownProps = [];

for (let property in duck) {
  if(duck.hasOwnProperty(property)) {
    ownProps.push(property);
  }
}

console.log(ownProps); // prints [ "name", "numLegs" ]

--instructions--

canary对象里面的自身属性添加到ownProps数组里面。

--hints--

ownProps应该包含'numLegs''name'两个属性的值。

assert(ownProps.indexOf('name') !== -1 && ownProps.indexOf('numLegs') !== -1);

在不使用内置方法Object.keys()的情况下完成这个挑战。

assert(!/Object(\.keys|\[(['"`])keys\2\])/.test(code));

You should solve this challenge without hardcoding the ownProps array.

assert(
  !/\[\s*(?:'|")(?:name|numLegs)|(?:push|concat)\(\s*(?:'|")(?:name|numLegs)/.test(
    code
  )
);

--solutions--