javascript语言扩展:可迭代对象(1)

时间:2023-12-21 18:54:38

在ECMAScript中我们知道可以通过for in语句进行对象属性的遍历,当然这些属性不包括继承而来的属性:

var ary = [1,2,3,"aa",4];
for(i in ary)
    console.log(i); //遍历属性名称

在firefox以及其他浏览器实现的js语言扩展中,增加了each语句,each和in类似,不过它遍历的是对象的属性值:

var a = [1,2,3,4];
for each(v in a)
    console.log(v); //遍历属性的值

在js扩展中还有更为通用的可迭代对象,in和each语句可以应用在任何可迭代对象;所谓可迭代对象是可以生成“下一个”值的对象,它要满足以下2个基本条件:

1.必须包含一个值为函数的__iterator__属性;

2.该函数必须返回一个对象,这个对象必须有一个next函数属性用来生成下一个值。一般来说我们将该对象称为迭代器对象;

如果你的目的是创建一个有限的迭代器(你并不想遍历死循环吧),那么当迭代到末尾时,需要抛出StopIteration异常;注意该异常只是个对象而已,并不是一个构造器函数,所以不必用new来创建。而each或in语句内部可以自动处理该异常,所以一般没必要自己写catch来手动捕获该异常以便跳出迭代器的干活了。

我们下面利用函数的闭包,将一个可迭代对象封装在一个函数中:

function get_itor(start,end){
  return{
    __iterator__:function(){
      return {
        next:function(){
            if(start>end) throw StopIteration;
            return start++;
        }
      };
    }
  };
}

下面这里写代码片分别用in和each来迭代可迭代器对象:

var itor = get_itor(1,10);
for(i in itor)
    console.log(i); //遍历值
for each(v in itor)
    console.log(v); //同样也是遍历值