乐趣区

原生js实现each方法

jquery 里面有个 each 方法,将循环操作简化、便捷。
随后 es 出了个 forEach 方法,两个虽然用法相近,但是不能处理对象类型。且无法通过 return true 达到 continue 效果。
此外还有个 every 方法,该方法虽然可以实现 continue 效果,但是在处理类数组与对象类型时,完全无用。

在不使用 jqueryeach方法时,该如何处理;或者说用原生如何来实现?
前些前写了个类库: jTool, 其中就实现了该方法。

简单实现:

// 通过字面量方式实现的函数 each
var each =  function(object, callback){var type = (function(){switch (object.constructor){
            case Object:
                return 'Object';
                break;
            case Array:
                return 'Array';
                break;
            case NodeList:
                return 'NodeList';
                break;
            default:
                return 'null';
                break;
        }
    })();
    // 为数组或类数组时, 返回: index, value
    if(type === 'Array' || type === 'NodeList'){
        // 由于存在类数组 NodeList, 所以不能直接调用 every 方法
        [].every.call(object, function(v, i){return callback.call(v, i, v) === false ? false : true;
        });
    }
    // 为对象格式时, 返回:key, value
    else if(type === 'Object'){for(var i in object){if(callback.call(object[i], i, object[i]) === false){break;}
        }
    }
}

我们来 try 一下,测试下数组、对象、类数组类型及中断效果

数组类型

var _array = [1,2,3,4];
each(_array, function(i, v){console.log(i + ':' + v);
});

输出如下:

对象类型

var object = {a:1, b:2, c:3}
each(object, function(i, v){
console.log(i + ‘: ‘ + v);
});
输出如下:

类数组类型

var ele = document.querySelectorAll('div');
each(ele, function(i, v){console.log(i + ':' + v);
});

输出如下:

增加中断条件

var object2 = {name:'baukh', age: '29', six:'男', url: 'www.lovejavascript.com',}
each(object2, function(i, v){if(i === 'age'){ // 如果存在键值为 age 的属性时,则输出警告,用于实现 continue 效果
    console.log('存在键值为 age,这家伙已经'+v+'岁了');
    return true;
  }
  if(i === 'six' && v === '男'){// 如果存在键值为 age 的属性时,则输出跳出,用于实现 break 效果
    console.log('存在键值为 six, 是个男的,不用关注了~');
    return false;
  }
  console.log(i + ':' + v);
});

输出如下:

从结果可以看出来,each 方法已经实现了 jquery 的 each 功能。且实现如此简单~

随笔一行
这是前端最好的时代,这也是前端最坏的时代。众多前端框架满天飞,随着 jQuery 在前端行业的慢慢弱化,总是会有一种斯人远去,何者慰籍的感觉。互勉吧,各位。

另推荐个表格组件 gridManager

退出移动版