如何在javascript中获取给定类型的所有对象

时间:2010-04-08 19:29:15

标签: javascript

我想检索使用“new”关键字创建的给定类型的所有对象(不是DOM元素)。

有可能吗?

function foo(name)
{
  this.name = name;
}

var obj = new foo();

如何检索对所有foo对象的引用?

2 个答案:

答案 0 :(得分:14)

没有内置方法可以做到这一点,但是,您可以轻松地让foo构造函数存储已创建对象的数组。

function foo(name)
{
  this.name = name;
  foo.objects.push(this);
}

foo.objects = [];

foo.prototype.remove = function() {
  for (var i=0; i<foo.objects.length; i++) {
    if (foo.objects[i] == this) {
      foo.objects.splice(i,1);
    }
  }
};

for (var i=0; i<10; i++) {
  var obj = new foo();
  obj.test = i;
}

// lets pretend we are done with #5
foo.objects[5].remove();

console.log(foo.objects);

//  [Object { test=0}, Object { test=1}, Object { test=2}, Object { test=3}, 
//   Object { test=4}, Object { test=6}, Object { test=7}, Object { test=8}, 
//   Object { test=9}]

答案 1 :(得分:6)

如果它们都是在全局范围内分配的,并且您不需要检查iframe / window边界,并且您不需要在IE中执行此操作(例如,您是只是尝试调试一些东西),你应该能够遍历全局范围:

var fooObjects = [];
for(var key in window) {
  var value = window[key];
  if (value instanceof foo) {
    // foo instance found in the global scope, named by key
    fooObjects.push(value)
  }
}

Buuuuut你可能在某些地方的函数内部实例化了一些foos,在这种情况下它们不可用。

您可以尝试在实例化之前修改构造函数:

var fooObjects = [];
var oldFoo = window.foo;
window.foo = function() {
  fooObjects.push(this);
  return oldFoo.apply(this, arguments);
}

foo.prototype = oldFoo.prototype;