2.5 KiB
2.5 KiB
id, title, challengeType, forumTopicId, dashedName
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
587d7dae367417b2b2512b7b | Розуміння власних властивостей | 1 | 301326 | understand-own-properties |
--description--
В наступному прикладі конструктор Bird
встановлює дві властивості name
й numLegs
:
function Bird(name) {
this.name = name;
this.numLegs = 2;
}
let duck = new Bird("Donald");
let canary = new Bird("Tweety");
name
й numLegs
називаються own properties, бо вони визначаються напряму від об'єкта. Це означає, що duck
й canary
мають власні копії цих властивостей. Насправді кожна частина Bird
повинна мати власну копію цих властивостей. Цей код надає змогу додати всі власні властивості duck
до масиву ownProps
:
let ownProps = [];
for (let property in duck) {
if(duck.hasOwnProperty(property)) {
ownProps.push(property);
}
}
console.log(ownProps);
Консоль повинна зображати значення ["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));
Ви повинні розв'язати це завдання без використання складного кодування ownProps
.
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);