Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6345751
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 24, 20262026-05-24T20:53:05+00:00 2026-05-24T20:53:05+00:00

Possible Duplicate: Is it an anti-pattern to modify JavaScript's built-in prototypes? I just learned

  • 0

Possible Duplicate:
Is it an anti-pattern to modify JavaScript's built-in prototypes?

I just learned that it’s possible to modify the JavaScript core objects, but the same article that told me how to do it suggested that I never should.

Is it a bad thing to modify a core JS object? If so, what problems could this cause?

As an example, here’s a modification of the Array object that gives me an easy way to search for a given value in an array:

Array.prototype.search = function(val){
    var i;
    for (i = 0; i < this.length; i++){
        if (this[i] == val) {
            console.log("found: " + val);
            return true;
        }
    }
    console.log("didn't find it");
    return false;
};

Here’s the article: Advanced Javascript: Objects, Arrays, and Array-Like objects

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-24T20:53:06+00:00Added an answer on May 24, 2026 at 8:53 pm

    Whether is bad or not is quite debatable, I really like the point of view that @kangax gives us in this article:

    • Extending built-in native objects. Evil or not?

    At first he separates the extension of host and native objects, with host objects there are no guarantees, there’s no a spec, and they have no rules.

    Host objects are those that are provided by the environment, they are not part of the ECMAScript specification, for example DOM objects.

    Extending native objects seems “less dangerous”, he explores the problems of enumerability, which seems to be a problem, the for-in statement enumerates all object properties, inherited or own, if you add a property on Object.prototype for example, any object used with this statement will show the property name.

    This statement is often abused to iterate over array objects, while it’s purpose is to enumerate object properties.

    At the end, I think the conclusion of this article is that extending native objects to shim standard compliant methods (e.g. ES5 Array methods (map, forEach, reduce, etc)) is encouraged, but extending natives to add custom non-standard compliant methods is discouraged.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Possible Duplicate: JavaScript: var functionName = function() {} vs function functionName() {} What's the
Possible Duplicate: PHP get all arguments as array? Within a javascript function arguments always
Possible Duplicate: How to call a JavaScript function from PHP? I have a php
Possible Duplicate: What is the difference between a function expression vs declaration in JavaScript?
Possible Duplicate: git - removing a file from source control (but not from the
Possible Duplicate: Best way to determine if two path reference to same file in
Possible Duplicate: Qt equivalent of PathAppend? Is there a class that handles file paths
Possible Duplicate: C++ templates that accept only certain types For example, if we want
Possible Duplicate: XPath: How to match attributes that contain a certain string I'm trying
Possible Duplicate: std::string and its automatic memory resizing I am just curious, how are

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.