Home > Web Front-end > JS Tutorial > What are the Differences Between Extending and Overwriting JavaScript Prototypes?

What are the Differences Between Extending and Overwriting JavaScript Prototypes?

Mary-Kate Olsen
Release: 2024-11-25 02:45:11
Original
626 people have browsed it

What are the Differences Between Extending and Overwriting JavaScript Prototypes?

Defining a JavaScript Prototype: Exploring Two Syntaxes and their Impacts

In JavaScript, defining prototypes offers a convenient way to add behavior to objects. Two common syntaxes exist for prototype definition, and they can have functional differences.

Option 1: Extending the Existing Prototype

Person.prototype.sayName = function(name) {
   alert(name);
}
Copy after login

This syntax extends the existing prototype object with a new property (sayName) and a function assigned to it. Objects instantiated before this definition can inherit the new method.

Option 2: Overwriting the Prototype

Person.prototype = {
   sayName: function(name) {
      alert(name);
   }
}
Copy after login

Here, the entire prototype object is replaced with a new one, containing only the sayName method. This overwrites all existing prototype properties, including the implicitly bound constructor property.

Functional Differences

  • Option 1 (Extending): Objects created before the prototype definition will inherit the new sayName method.
  • Option 2 (Overwriting): Only objects instantiated after the prototype overwriting will use the new prototype.

Benefits and Drawbacks

  • Option 1 (Extending) is preferrable: It's cleaner and maintains existing prototype properties. It's essential for modifying prototypes of external classes.
  • Avoid Option 2 (Overwriting): It can trash the constructor property and disrupt existing prototype chains.

Alternative Syntax for Extending:

For a cleaner object literal syntax without overwriting, consider using Object.assign:

Object.assign(Person.prototype, {
   sayName: function(name) {
      alert(name);
   }
});
Copy after login

The above is the detailed content of What are the Differences Between Extending and Overwriting JavaScript Prototypes?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template