Tuesday, January 7, 2025
Google search engine
HomeLanguagesJavascriptJavaScript Object.prototype.valueOf() Method

JavaScript Object.prototype.valueOf() Method

In JavaScript, the Object.prototype.valueOf() method is used to return the primitive value of the specified object. Whenever a primitive value is required, JavaScript automatically invokes the valueOf() method. The valueOf() method is automatically inherited by every object in JavaScript. Every object overrides this method to return an appropriate primitive value. If no primitive value is present for this object, then JavaScript returns the object itself. We can override this method to convert any built-in object to a primitive value. In the case of Custom object types, we override this method to call a custom method.

If we are dealing with custom object types, we can use the following syntax to override valueOf() method for it :

Syntax:

ObjectType.prototype.valueOf = function() { 
return CustomPrimitiveValue;
};

In this syntax,

  • ObjectType: The custom object type created by the user.
  • CustomPrimitiveValue: The primitive value of the specified object.

Although the valueOf() method is automatically invoked in JavaScript, we can use the following syntax to invoke it ourselves

Syntax:

ObjectType.valueOf()

Example: In this example, we tried to override the valueOf() method to return the primitive value as the actual number plus 3. Thus the primitive value returned after passing 18 as the argument was 21. As we tried to log primitive value minus 12, we got 21-12 which is 9 as our final answer.

JavaScript




function myFunction() {
 
    // Creating a custom object
    // type ExType
    function ExType(n) {
        this.number = n;
    }
 
    // A callback method overriding
    // the valueOf() method
    ExType.prototype.valueOf = function () {
 
        // Returned valued is 18+3 which is 21
        return this.number + 3;
    };
 
    // Creating an object of ExType object type
    const object1 = new ExType(18);
 
    // Logs 21-12 which is 9
    console.log(object1 - 12);
}
 
myFunction();


Output

9

Example:  In this example, the person object has properties of name and age. toString() returns the name and age, and valueOf() returns the age as the primitive value.

Javascript




const person = {
    name: "John",
    age: 30,
    toString() {
        return `Name: ${this.name}, Age: ${this.age}`;
    },
    valueOf() {
        return this.age;
    }
};
 
console.log(person.toString());
// Output: "Name: John, Age: 30"
console.log(person.valueOf());
// Output: 30


Output

Name: John, Age: 30
30

Supported Browsers:

  • Chrome 1 and above
  • Edge 12 and above
  • Firefox 1 and above
  • Opera 3 and above
  • Safari 1 and above
Whether you’re preparing for your first job interview or aiming to upskill in this ever-evolving tech landscape, neveropen Courses are your key to success. We provide top-quality content at affordable prices, all geared towards accelerating your growth in a time-bound manner. Join the millions we’ve already empowered, and we’re here to do the same for you. Don’t miss out – check it out now!

RELATED ARTICLES

Most Popular

Recent Comments