Home >Web Front-end >JS Tutorial >Summary of defects of Javascript for in

Summary of defects of Javascript for in

高洛峰
高洛峰Original
2017-02-08 17:31:531131browse

Summary of defects in Javascript for in

The for in statement is used to list the properties (members) of an object, as follows

var obj = { name:"jack",
   getName:function(){return this.name}
};
//输出name,getName 
for(var atr in obj) {
  alert(atr);
}

Did you notice that obj is not output? Built-in properties such as toString and valueOf (or built-in members, hidden properties and predefined properties). That is, for in is used to list the displayed members (custom members) of the object.

If you rewrite the built-in properties, let's rewrite obj's toString

var obj = {name:"jack",
   getName:function(){return this.name},
   toString:function(){return "I'm jack."}
}
for(var atr in obj) {
  alert(atr);
}

What will be output?

1. Under IE6/7/8, it is the same as not rewriting toString. It still only outputs name and getName

2. IE9/Firefox/Chrome/Opera/Safari The following outputs name, getName, toString

If you add properties/methods to the built-in prototype, it will also be traversable during for in

Object.prototype.clone = function() {}
var obj = {
  name: 'jack',
  age: 33
}
// name, age, clone
for (var n in obj) {
  alert(n)
}

Added to Object.prototype Method clone, all browsers display clone when for in.

This may not be a big deal, because it is generally not recommended to extend the prototype of the built-in constructor, which is also one of the reasons for the decline of Prototype.js. jQuery and Underscore do not extend the self-prototype. The former makes a fuss about the jQuery object, and the latter simply hangs all methods under underscore.

But sometimes in order to be compatible with ES5 or subsequent versions, we will extend the prototype of the built-in constructor on browsers that do not support ES5 (IE6/7/8). In this case, for in will It’s different. As shown below

if (!Function.prototype.bind) {
  Function.prototype.bind = function(scope) {
    var fn = this
    return function () {
      fn.apply(scope, arguments)
    }
  }
}
function greet(name) {
  alert(this.greet + ', ' + name)
}
for (var n in greet) {
  alert(n)
}

IE6/7/8 outputs bind, but other browsers do not. Because bind is natively supported in modern browsers, and for in is not available, IE6/7/8 adds bind to Function.prototype.

To summarize: In cross-browser design, we cannot rely on for in to obtain the member names of the object. We generally use hasOwnProperty to judge.

Thank you for reading, I hope it can help you, thank you for your support of this site!

For more articles related to Javascript for in defect summary, please pay attention to the PHP Chinese website!

Statement:
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