Home > front end >  Objects and comparing in Javascript, how to pass the value into the method
Objects and comparing in Javascript, how to pass the value into the method

Time:05-06

I got this Javascript exercise. I couldn't figure out how to pass the value of the pay of each person into the "comparePay" method. I'd be glad if you help me this.

Thank you in advance.


Create 3 Person objects, with the attributes "name", "occupation" and "pay", as well as the method "comparePay(person)", which compares the pay values of the object calling it and the object passed to it as argument, then printing the result:

[name of object calling the method] earns [difference] more than [other's name]
[name of object calling the method] earns [difference] less than [other's name]
[name of object calling the method] earns as much as [name]

The objects should have the following values:

Michael, JS-programmer, 5000
Lena, Python-programmer, 1500
Brad, Teacher, 800

The output should be like this.↓

First person's name: Michael
Second person's job: Python-programmer
Third person's pay: 800

Michael earns 3500 more than Lena
Brad earns 700 less than Lena
Brad earns as much as Brad

Here is what I have done so far.

 function Person(name, occupation, pay) {
      this.name = name;
      this.occupation = occupation;
      this.pay = pay;
     this.comparePay = function(person) { /* compare the value of the pay */
         var difference = person.pay - person.pay;
         if (difference > 0) {
             return person.name   " earns "   difference   " more than "   person.name;
         } else if (difference === 0) {
             return person.name   " earns as much as "   person.name;
         } else {
             return person.name   " earns "   Math.abs(difference)   " less than "   person.name;
         } 
        };
     }

    person1 = new Person("Michael", "JS-programmer", 5000);
    person2 = new Person("Lena", "Python-programmer", 1500);
    person3 = new Person("Brad", "Teacher", 800);

and here is the prepared code, so they are not allowed to be edited.

console.log("First person's name: "   person1.name);
console.log("Second person's job: "   person2.occupation);
console.log("Third person's pay: "   person3.pay   "\n");

person1.comparePay(person2);
person3.comparePay(person2);
person3.comparePay(person3);

CodePudding user response:

function Person(name, occupation, pay) {
      this.name = name;
      this.occupation = occupation;
      this.pay = pay;
     this.comparePay = function(person) { /* compare the value of the pay */
         var difference = this.pay - person.pay;
         if (difference > 0) {
             return this.name   " earns "   difference   " more than "   person.name;
         } else if (difference === 0) {
             return this.name   " earns as much as "   person.name;
         } else {
             return this.name   " earns "   Math.abs(difference)   " less than "   person.name;
         } 
        };
     }

person1 = new Person("Michael", "JS-programmer", 5000);
person2 = new Person("Lena", "Python-programmer", 1500);
person3 = new Person("Brad", "Teacher", 800);

console.log(person1.name);
console.log(person1.pay);
console.log(person2.name);
console.log(person2.pay);
console.log(person3.name);
console.log(person3.pay);

console.log( person1.comparePay(person2) );
console.log( person3.comparePay(person2) );
console.log( person2.comparePay(person1) );
console.log( person3.comparePay(person3) );

Inside the this.comparePay function you should use this to access the object properties:

this.pay, this.name, etc.

this.comparePay = function(person) { 
  var difference = this.pay - person.pay;
  ...
}

CodePudding user response:

I think the problem comes from your comparaison (you're comparing the same object attributes). You want to compare the object passed in the function's argument with the current object.

So I guess you can try to replace

var difference = person.pay - person.pay;

by

const difference = this.pay - person.pay;

Same for

return person.name " earns " difference " more than " person.name;

should be

return this.name " earns " difference " more than " person.name;

Otherwise it will return the same names. You can also use template literals notation

return `${this.name} earns ${difference} more than ${person.name}`;

Hope it makes sense. Also don't forget to use let or const instead of var :)

  • Related