2.1 KiB
id, title, challengeType, forumTopicId, dashedName
| id | title | challengeType | forumTopicId | dashedName |
|---|---|---|---|---|
| 587d7dae367417b2b2512b7b | Entender propriedades próprias | 1 | 301326 | understand-own-properties |
--description--
No próximo exemplo, o construtor de Bird define duas propriedades: name e numLegs:
function Bird(name) {
this.name = name;
this.numLegs = 2;
}
let duck = new Bird("Donald");
let canary = new Bird("Tweety");
name e numLegs são chamados own properties, pois são definidos diretamente na instância do objeto. Isso significa que cada duck e canary possuem suas próprias cópias separadas destas propriedades. Na verdade, toda instância de Bird terá sua própria cópia dessas propriedades. O código a seguir adiciona todas as propriedades próprias (own properties) de duck para o array ownProps:
let ownProps = [];
for (let property in duck) {
if(duck.hasOwnProperty(property)) {
ownProps.push(property);
}
}
console.log(ownProps);
O console vai exibir o valor ["name", "numLegs"].
--instructions--
Adicione as propriedades próprias do canary para o array ownProps.
--hints--
ownProps deve incluir os valores numLegs e name.
assert(ownProps.indexOf('name') !== -1 && ownProps.indexOf('numLegs') !== -1);
Você deve resolver este desafio sem utilizar o método nativo Object.keys().
assert(!/Object(\.keys|\[(['"`])keys\2\])/.test(code));
Você deve resolver este desafio sem definir o array ownProps de forma fixa no código.
assert(
!/\[\s*(?:'|")(?:name|numLegs)|(?:push|concat)\(\s*(?:'|")(?:name|numLegs)/.test(
code
)
);
--seed--
--seed-contents--
function Bird(name) {
this.name = name;
this.numLegs = 2;
}
let canary = new Bird("Tweety");
let ownProps = [];
// Only change code below this line
--solutions--
function Bird(name) {
this.name = name;
this.numLegs = 2;
}
let canary = new Bird("Tweety");
function getOwnProps (obj) {
const props = [];
for (let prop in obj) {
if (obj.hasOwnProperty(prop)) {
props.push(prop);
}
}
return props;
}
const ownProps = getOwnProps(canary);