迭代器模式是指提供一种方法顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示。
迭代器模式可以把迭代的过程从业务逻辑中分离出来,在使用迭代器模式之后,即使不关心对象的内部构造,也可以按顺序访问其中的每个元素
许多浏览器都支持 Javascript 的 Array.prototype.forEach
迭代器可以分为 内部迭代器 和 外部迭代器

一、jQuery 中的迭代器
 $.each( [1,2,3,4], function (i, n) {
console.log( "当前下表为:" + i + " , 当前值为:" + n );
});
二、自实现一个迭代器
 // 自己实现一个数组迭代器
var each = function( arry, callback ){
for( var i = 0, l = arry.length; i < l; i++){
callback.call( arry[i], i, arry[ i ]);
}
};
each([1,2,3,4], function (i, n) {
console.log( i + " - " + n ); // 输出数组下标和值
});
三、内部迭代器

  上边的 each 函数属于内部迭代器, each 函数内部已经定义好了迭代原则,它完全接手整个迭代过程,外部只需要一次初始调用。
  内部迭代器的优点也刚好是它的缺点 - 使用方便,迭代交互也仅仅是一次初始调用
  示例: 在不改写 each 本身的代码前提,实现判断两个数组里元素的值是否完全相等
 //判断两个数组的值是否完全相等
var compare = function( arry1, arry2){
if( arry1.length !== arry2.length ){
throw new Error( "arry1和arry2不相等" );
}
each( arry1, function( i, n ){
if( n !== arry2[i] ){
throw new Error("arry1和arry2不相等");
}
});
console.log( "arry1和arry2相等" );
}; compare( [1,2,3,4], [1,2,3]);

 四、外部迭代器
  外部迭代器必须显式地请求迭代下一个元素
  外部迭代器增加了一些调用的复杂度,但相对的也增强了迭代器的灵活性,我们可以手工控制迭代的过程或者顺序
  示例: 重写 compare     外部迭代器:
 // 外部迭代器
var Iterator = function (obj) {
var current = 0; var next = function(){
current += 1;
}; var isDone = function(){
return current >= obj.length;
}; var getCurrItem = function(){
return obj[ current ];
}; return {
next: next,
isDone: isDone,
getCurrItem: getCurrItem
}
}


    改写 Compare   
 // 改写 Compare
var compare = function( iterator1, iterator2 ){
while( iterator1.isDone() && iterator2.isDone() ){
if( iterator1.getCurrItem() !== iterator2.getCurrItem() ){
throw new Error( "iterator1 和 iterator2不相等" );
}
iterator1.next();
iterator2.next();
}
console.log( "iterator1 和 iterator2相等" );
}; var iterator1 = Iterator( [1,2,3,4] );
var iterator2 = Iterator( [1,2,3,4] ); compare(iterator1,iterator2);

 五、中止迭代器
  重写 each 函数实现中止迭代
 // 重写 each 函数实现中止迭代
var each = function( arry, callback ){
for( var i = 0, l = arry.length; i < l; i++ ){
// callback 的执行结果返回false,提前中止迭代
if( callback( i, arry[i] ) === false ){
break;
}
}
};
each( [1,2,3,4,5], function ( i, n ) {
if( n>3 ){ // n 大于3的时候中止循环
return false;
}
console.log(n); // 输出 1 2 3
});

 六、迭代器应用示例
  目的:根据不同的浏览器获取相应的上传组件对象
    
    将不同的上传对象封装到各自的函数里; 如果函数可用,则返回该对象,否则返回false,提示迭代器继续
 // 将不同的上传对象封装到各自的函数里; 如果函数可用,则返回该对象,否则返回false,提示迭代器继续
var getActiveUploadObj = function(){
try{
return new ActiceXObject( "TXFTNActiveX.FTNUpload" ); // IE 上传控件
}catch(e){
return false;
}
};
var getFlashUploadObj = function(){
if( supportFlash() ){
var str = "<object type='application/x-shockwave-flash'></object>";
return $( str).appendTo( $("body") );
}
return false;
};
var getFormUpl0adObj = function(){
var str = "<input type='file' type='file' class='ui-file' />"; // 表单上传
return $( str).appendTo( $("body") );
};
     //迭代器代码
 //迭代器代码
var iteratorUploadObj = function(){
for( var i = 0, fn; fn = arguments[ i++ ]; ){
var uploadObj = fn();
if( uploadObj !== false ){
return uploadObj;
}
}
}; var uploadObj = iteratorUploadObj( getActiveUploadObj, getFlashUploadObj, getFormUpl0adObj );

七、总结
迭代模式相对简单,简单到很多时候我们不认为它是一种设计模式
阅读参考书籍 - << JavaScript 设计模式与开发实践 >>

JavaScript设计模式 - 迭代器模式的更多相关文章

  1. javascript设计模式——迭代器模式

    前面的话 迭代器模式是指提供一种方法顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示.迭代器模式可以把迭代的过程从业务逻辑中分离出来,在使用迭代器模式之后,即使不关心对象的内部构造,也 ...

  2. javascript设计模式-迭代器模式(Iterator)

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. 19. 星际争霸之php设计模式--迭代器模式

    题记==============================================================================本php设计模式专辑来源于博客(jymo ...

  4. java设计模式——迭代器模式

    一. 定义与类型 定义:提供一种方法,顺序访问一个集合对象中的各个元素,而又不暴露该对象的内部表示 类型:行为型. 二. 使用场景 (1) 访问一个集合对象的内容而无需暴露它的内部表示 (2)  为遍 ...

  5. js设计模式--迭代器模式

    迭代器模式: 迭代器模式提供一种方法顺序访问一个聚合对象中各个元素,而又不需要暴露该方法中的内部表示.js中我们经常会封装一个each函数用来实现迭代器. 理解的意思:提供一个方法,去把对象的每一项按 ...

  6. [Head First设计模式]生活中学设计模式——迭代器模式

    系列文章 [Head First设计模式]山西面馆中的设计模式——装饰者模式 [Head First设计模式]山西面馆中的设计模式——观察者模式 [Head First设计模式]山西面馆中的设计模式— ...

  7. javascript 设计模式-----策略模式

    在<javascript设计模式>中,作者并没有向我们介绍策略模式,然而它却是一种在开发中十分常见的设计模式.最常见的就是当我们遇到一个复杂的表单验证的时候,常常需要编写一大段的if和el ...

  8. JAVA 设计模式 迭代器模式

    用途 迭代器模式 (Iterator) 提供一种方法顺序访问一个聚合对象中各个元素,而又不暴露该对象的内部表示. 迭代器模式是一种行为型模式. 结构

  9. 深入浅出设计模式——迭代器模式(Iterator Pattern)

    模式动机 一个聚合对象,如一个列表(List)或者一个集合(Set),应该提供一种方法来让别人可以访问它的元素,而又不需要暴露它的内部结构.针对不同的需要,可能还要以不同的方式遍历整个聚合对象,但是我 ...

随机推荐

  1. NOI题库-小学奥赛QwQ

    今天Loli教育我们让我们来看看NOI题库的奥赛部分,不过,为何是小学的( ⊙ o ⊙ )啊!感觉智商被各种侮辱. 余数相同问题: 描述 已知三个正整数 a,b,c. 现有一个大于1的整数x,将其作为 ...

  2. Session解析

    1.除非关闭所有页面 或者超时session才销毁 2.在几个页面之间切换的时候 session保存用户状态. 3.遍历数组时候for循环中从0开始小于长度,不等于长度,用Matlab用习惯了,竟然从 ...

  3. BZOJ2535 [Noi2010]Plane 航空管制2

    Description 世博期间,上海的航空客运量大大超过了平时,随之而来的航空管制也频频发生.最近,小X就因为航空管制,连续两次在机场被延误超过了两小时.对此,小X表示很不满意. 在这次来烟台的路上 ...

  4. 浅谈datagrid详细操作单元格样式

    http://www.easyui.info/archives/470.html 今天有朋友问到:“如果设置列标题居中而列内容居右显示?”,仔细查了一下api,目前版本提供了两个相关的列属性,alig ...

  5. x86汇编指令详解

    80x86指令系统 80x86指令系统,指令按功能可分为以下七个部分. (1) 数据传送指令. (2) 算术运算指令. (3) 逻辑运算指令. (4) 串操作指令. (5) 控制转移指令. (6) 处 ...

  6. WAMP 403 Forbidden禁止访问

    WAMP .5修改方法 修改httpd.conf文件 # onlineoffline tag - don't remove Require local To # onlineoffline tag - ...

  7. c++新特性与boost

    <Boost程序库探秘——深度解析C++准标准库>之试读 前一阵子还看到一篇文章,说C#要重蹈C++的覆辙,这里说的C++的覆辙是什么呢?是指C++语言过于臃肿的功能特性,导致学习人员的流 ...

  8. redis哨兵配置主从

    redis哨兵的启动和redis实例的启动没有关系.所以可以在任何机器上启动redis哨兵.至少要保证有两个哨兵在运行,要不然宕机后哨兵会找不到主节点. 配置步骤: 1.在redis的配置文件中添加鉴 ...

  9. C#实现eval 进行四则运算

    昨天在园子里看到有园友,写了相同标题的一篇文章.重点讲的是中缀表达式转换为后缀表达式的算法,但是实现的四则运算 有bug.其实我没看之前也不懂什么是 中缀和后缀表达式,之前有用过js eval 内置函 ...

  10. JS自动格式化输入的数字/千位分隔符VIEW:858

    <script> function cc(s){ if(/[^0-9\.]/.test(s)) return "invalid value"; ss=s.replace ...