Is hasOwnProperty() method case-sensitive? Is there any other alternative case-insensitive version of hasOwnProperty?
- 
                    Java Script is not case insensitive, so there's no alternative on that. But why you want it case insensitive? – Ortiga Apr 29 '11 at 13:52
- 
                    Related: [Are javascript object keys case-sensitive?](https://stackoverflow.com/q/42400548/1048572), [Access JavaScript property case-insensitively?](https://stackoverflow.com/q/12484386/1048572) – Bergi Dec 14 '20 at 21:28
3 Answers
Yes, it's case sensitive (so obj.hasOwnProperty('x') !== obj.hasOwnProperty('X')) You could extend the Object prototype (some people call that monkey patching):
Object.prototype.hasOwnPropertyCI = function(prop) {
      return ( function(t) {
         var ret = [];
         for (var l in t){
             if (t.hasOwnProperty(l)){
                 ret.push(l.toLowerCase());
             }
         }
         return ret;
     } )(this)
     .indexOf(prop.toLowerCase()) > -1;
}
More functional:
Object.prototype.hasOwnPropertyCI = function(prop) {
   return Object.keys(this)
          .filter(function (v) {
             return v.toLowerCase() === prop.toLowerCase();
           }).length > 0;
};
 
    
    - 119,216
- 31
- 141
- 177
Old question is old; but still entirely relevant. I searched for a quick answer to this question as well, and ended up figuring out a good solution before I read this, so I thought I'd share it.
Object.defineProperty(Object, 'hasOwnPropertyCI', {
    enumerable: false,
    value: (keyName) => (
        Object.keys(this).findIndex(
            v => v.toUpperCase() === keyName.toUpperCase()
        ) > -1
    }
});
This resolves to true when keyName exists in the object it's called on:
var MyObject = { "foo": "bar" };
MyObject.hasOwnPropertyCI("foo");
Hope that helps someone else! :D
PS: Personally, my implementation slaps the conditional above into an IF statement, since I won't be using it anywhere else in my application (in addition to the fact that I'm not a huge fan of manipulating native prototypes).
 
    
    - 3,020
- 26
- 36
- 
                    I like the implementation. The question I have now is how to refer the property if we don't know its case? Say, if (!this.states.hasOwnPropertyCI(area)) { this.states[area] = {}; } if (!this.states[area].hasOwnPropertyCI(page)) { this.states[area][page] = {}; } How should I use this.states[area] to be able to refer to this property without having area in correct case? – Naomi Mar 21 '18 at 19:35
- 
                    @Naomi Technically you could modify hasOwnPropertyCI to _return_ the key's actual name if it finds it, rather than just `true`. You can do so simply by using `.find()` instead of `.findIndex()`, and removing the `> -1` – Swivel Sep 19 '18 at 20:25
Yes, it's case sensitive, because JavaScript is case sensitive.
There is no alternative built-into the language, but you could roll your own:
function hasOwnPropertyCaseInsensitive(obj, property) {
    var props = [];
    for (var i in obj) if (obj.hasOwnProperty(i)) props.push(i);
    var prop;
    while (prop = props.pop()) if (prop.toLowerCase() === property.toLowerCase()) return true;
    return false;
}
 
    
    - 11,232
- 4
- 24
- 32
- 
                    2I won't ask *why* you want to do this, I'm sure there's a good reason... also, if you want the actual property in its correct case, replace `return true` with `return prop` – Stoive Apr 29 '11 at 13:58
- 
                    1I commonly use a case in-sensitive check when parsing data from external systems or that might be user entry, because javascript is sensitive, I need to make sure the input is correct. – Chris Schaller Oct 23 '15 at 04:30
 
    