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

在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); //同样也是遍历值
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值