* chore(learn): audit basic algorithm scripting * chore(learn): audit basic data structures * chore(learn): audit basic javascript * chore(learn): audit debugging * chore(learn): audit es6 * chore(learn): audit functional programming * chore(learn): audit intermidate algorithms * chore(learn): audit js projects * chore(learn): audit object oriented programming * chore(learn): audit regex * fix(learn): remove stray . * fix(learn): string to code * fix(learn): missed some * fix(learn): clarify strings Based on Randy's feedback, clarifies string instances where quotes were removed in favour of back ticks. * fix: apply suggestions - thanks Randy! :) Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com> * fix: non-suggestion comments * chore(learn): remove comments from codes Removes the comments from the description and instruction code blocks to ensure that all relevant information is translatable. * fix: Apply suggestions from code review Co-authored-by: Shaun Hamilton <51722130+ShaunSHamilton@users.noreply.github.com> * fix: revert crowdin fix * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/basic-algorithm-scripting/mutations.md Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com> * fix: Apply suggestions from code review Co-authored-by: Shaun Hamilton <51722130+ShaunSHamilton@users.noreply.github.com> * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/es6/use-destructuring-assignment-to-assign-variables-from-arrays.md Co-authored-by: Shaun Hamilton <51722130+ShaunSHamilton@users.noreply.github.com> * fix: Apply suggestions from code review Co-authored-by: Oliver Eyton-Williams <ojeytonwilliams@gmail.com> Co-authored-by: Shaun Hamilton <51722130+ShaunSHamilton@users.noreply.github.com> * chore: change voice * fix: Christopher Nolan * fix: expressions would evaluate * fix: will -> would * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/object-oriented-programming/add-methods-after-inheritance.md Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com> * fix: to work to push * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/basic-javascript/iterate-with-javascript-for-loops.md Co-authored-by: Shaun Hamilton <51722130+ShaunSHamilton@users.noreply.github.com> * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/object-oriented-programming/add-methods-after-inheritance.md Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com> Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com> Co-authored-by: Shaun Hamilton <51722130+ShaunSHamilton@users.noreply.github.com> Co-authored-by: Oliver Eyton-Williams <ojeytonwilliams@gmail.com>
3.5 KiB
id, title, challengeType, forumTopicId, dashedName
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
a2f1d72d9b908d0bd72bb9f6 | Make a Person | 5 | 16020 | make-a-person |
--description--
Fill in the object constructor with the following methods below:
getFirstName()
getLastName()
getFullName()
setFirstName(first)
setLastName(last)
setFullName(firstAndLast)
Run the tests to see the expected output for each method. The methods that take an argument must accept only one argument and it has to be a string. These methods must be the only available means of interacting with the object.
--hints--
Object.keys(bob).length
should return 6.
assert.deepEqual(Object.keys(bob).length, 6);
bob instanceof Person
should return true
.
assert.deepEqual(bob instanceof Person, true);
bob.firstName
should return undefined
.
assert.deepEqual(bob.firstName, undefined);
bob.lastName
should return undefined
.
assert.deepEqual(bob.lastName, undefined);
bob.getFirstName()
should return the string Bob
.
assert.deepEqual(bob.getFirstName(), 'Bob');
bob.getLastName()
should return the string Ross
.
assert.deepEqual(bob.getLastName(), 'Ross');
bob.getFullName()
should return the string Bob Ross
.
assert.deepEqual(bob.getFullName(), 'Bob Ross');
bob.getFullName()
should return the string Haskell Ross
after bob.setFirstName("Haskell")
.
assert.strictEqual(
(function () {
bob.setFirstName('Haskell');
return bob.getFullName();
})(),
'Haskell Ross'
);
bob.getFullName()
should return the string Haskell Curry
after bob.setLastName("Curry")
.
assert.strictEqual(
(function () {
var _bob = new Person('Haskell Ross');
_bob.setLastName('Curry');
return _bob.getFullName();
})(),
'Haskell Curry'
);
bob.getFullName()
should return the string Haskell Curry
after bob.setFullName("Haskell Curry")
.
assert.strictEqual(
(function () {
bob.setFullName('Haskell Curry');
return bob.getFullName();
})(),
'Haskell Curry'
);
bob.getFirstName()
should return the string Haskell
after bob.setFullName("Haskell Curry")
.
assert.strictEqual(
(function () {
bob.setFullName('Haskell Curry');
return bob.getFirstName();
})(),
'Haskell'
);
bob.getLastName()
should return the string Curry
after bob.setFullName("Haskell Curry")
.
assert.strictEqual(
(function () {
bob.setFullName('Haskell Curry');
return bob.getLastName();
})(),
'Curry'
);
--seed--
--after-user-code--
if(bob){
bob = new Person("Bob Ross");
}
--seed-contents--
var Person = function(firstAndLast) {
// Only change code below this line
// Complete the method below and implement the others similarly
this.getFullName = function() {
return "";
};
return firstAndLast;
};
var bob = new Person('Bob Ross');
bob.getFullName();
--solutions--
var Person = function(firstAndLast) {
var firstName, lastName;
function updateName(str) {
firstName = str.split(" ")[0];
lastName = str.split(" ")[1];
}
updateName(firstAndLast);
this.getFirstName = function(){
return firstName;
};
this.getLastName = function(){
return lastName;
};
this.getFullName = function(){
return firstName + " " + lastName;
};
this.setFirstName = function(str){
firstName = str;
};
this.setLastName = function(str){
lastName = str;
};
this.setFullName = function(str){
updateName(str);
};
};
var bob = new Person('Bob Ross');
bob.getFullName();