一个奇怪的javascript extend问题
发布于 10 年前 作者 guotie 4128 次浏览 最后一次编辑是 8 年前

代码在这里:

http://jsbin.com/xabowoyihawe/1/edit?js,console

问题: 为什么noop.name可以取到值而noop.title是undefined?而name和title都是在noop.prototype中的

function noop() {   }
function _extend(source, obj) {
  for (var prop in source) {
    if(!obj.prototype[prop]) {
      obj.prototype[prop] = source[prop]
    }
  }
  return obj
}

noop.prototype["name"] = 'noop'

_extend({"title":"sometitle"}, noop)

var n = new noop()
console.log( noop.name, noop.title, noop.prototype.name, noop.prototype.title, noop.prototype)
console.log( n.name, n.title)
1 回复

noop.name,取到的是Function实例的name,和你后面的逻辑没有关系。 var noop = function(){} 或者 var noop = new Function(); 或者在你原来代码基础上,第2行直接输出 console.log(noop.name); 这样你应该能理解了吧?

回到顶部