2021-06-15 00:49:18 -07:00
---
id: 587d7dae367417b2b2512b7b
2021-07-21 20:53:20 +05:30
title: Entender propriedades próprias
2021-06-15 00:49:18 -07:00
challengeType: 1
forumTopicId: 301326
dashedName: understand-own-properties
---
# --description--
2021-07-16 11:03:16 +05:30
No próximo exemplo, o construtor de `Bird` define duas propriedades: `name` e `numLegs` :
2021-06-15 00:49:18 -07:00
```js
function Bird(name) {
2022-01-21 01:00:18 +05:30
this.name = name;
2021-06-15 00:49:18 -07:00
this.numLegs = 2;
}
let duck = new Bird("Donald");
let canary = new Bird("Tweety");
```
2021-07-16 11:03:16 +05:30
`name` e `numLegs` são chamados < dfn > own properties</ dfn > , 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` :
2021-06-15 00:49:18 -07:00
```js
let ownProps = [];
for (let property in duck) {
if(duck.hasOwnProperty(property)) {
ownProps.push(property);
}
}
console.log(ownProps);
```
2021-07-29 02:37:39 +09:00
O console vai exibir o valor `["name", "numLegs"]` .
2021-06-15 00:49:18 -07:00
# --instructions--
2021-07-16 11:03:16 +05:30
Adicione as propriedades próprias do `canary` para o array `ownProps` .
2021-06-15 00:49:18 -07:00
# --hints--
2021-07-16 11:03:16 +05:30
`ownProps` deve incluir os valores `numLegs` e `name` .
2021-06-15 00:49:18 -07:00
```js
assert(ownProps.indexOf('name') !== -1 & & ownProps.indexOf('numLegs') !== -1);
```
2021-07-16 11:03:16 +05:30
Você deve resolver este desafio sem utilizar o método nativo `Object.keys()` .
2021-06-15 00:49:18 -07:00
```js
assert(!/Object(\.keys|\[(['"`])keys\2\])/.test(code));
```
2021-07-16 11:03:16 +05:30
Você deve resolver este desafio sem definir o array `ownProps` de forma fixa no código.
2021-06-15 00:49:18 -07:00
```js
assert(
!/\[\s*(?:'|")(?:name|numLegs)|(?:push|concat)\(\s*(?:'|")(?:name|numLegs)/.test(
code
)
);
```
# --seed--
## --seed-contents--
```js
function Bird(name) {
this.name = name;
this.numLegs = 2;
}
let canary = new Bird("Tweety");
let ownProps = [];
// Only change code below this line
```
# --solutions--
```js
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);
```