underscorejs-each学习
2.1 each
2.1.1 语法:
_.each(list, iteratee, [context])
2.1.2 说明:
依次对集合的所有元素进行某种操作,原样返回list。接收3个参数,list集合可以理解为数据源;iteratee即迭代器可以理解为回调方法;context执行上下文。
- list可以为数组,对象,字符串和arguments
- iteratee 会传第三个参数(element, index, list)或(value, key, list)
- context可以改变iteratee内部的this
2.1.3 代码示例:
示例一:each可以循环数组、对象、字符串和arguments
//遍历数组
_.each([1, 2, 3], function (element, index, list) {
console.log(element);
});
//遍历对象
_.each({one: '一', two: '二', three: '三'}, function(value, key, list){
console.log(value);
});
//遍历字符串
_.each('123', function(element, index, list){
console.log(element);
});
//遍历arguments
function abc(){
_.each(arguments, function(element, index, list){
console.log(element);
});
}
abc(1, 2, 3);
示例二:iteratee传递的参数
//数组的情况
_.each([1, 2, 3], function (element, index, list) {
console.log(element, index, list);
//1 0 [1, 2, 3]
//2 1 [1, 2, 3]
//3 2 [1, 2, 3]
});
//对象的情况
_.each({one: '一', two: '二', three: '三'}, function(value, key, list){
console.log(value, key, list);
//一 one Object {one: "一", two: "二", three: "三"}
//二 two Object {one: "一", two: "二", three: "三"}
//三 three Object {one: "一", two: "二", three: "三"}
});
示例三:context可以改变iteratee内部的this
_.each([1], function (element, index, list) {
console.log(this); //window
});
_.each([1], function (element, index, list) {
console.log(this); //{key: 1}
}, {key : 1});
示例四:each的返回值
var arr1 = _.each([1, 2, 3], function (element, index, list) {
});
var arr2 = _.each({one: '一', two: '二', three: '三'}, function(element, index, list){
});
console.log(arr1); //[1, 2, 3]
console.log(arr2); //Object {one: "一", two: "二", three: "三"}
2.1.4 _.forEach的功能和_.each是一样的
_.forEach([1, 2, 3], function (element, index, list) {
console.log(element);
});
2.1.5 遍历非集合
_.each(null, function (element, index, list) {
console.log(element); //不执行
});
_.each(undefined, function (element, index, list) {
console.log(element); //不执行
});
_.each(123, function (element, index, list) {
console.log(element); //不执行
});
_.each(new Date(), function (element, index, list) {
console.log(element); //不执行
});
遍历特殊值都不会报错,但也不执行。在遍历一个集合的时候,最好能先确定他是数组或对象等。
2.1.6 iteratee还可以是全局的方法
_.each([1, 2, 3], alert); //会弹三次
2.1.7 iteratee里面console.log为什么不行?(坑)
_.each([1, 2, 3], console.log); //Uncaught TypeError: Illegal invocation
gitbook地址:https://www.gitbook.com/book/niec-fe/underscorejs/details
underscorejs-each学习的更多相关文章
- 不学就吃亏的underscorejs类库学习示例 ——(集合篇)
underscorejs是一个很不错的类库,我的很多项目都引用了这个类库,的确可以带来很多方便. 记得我当初学的时候,看underscorejs的api是看的一知半解的,甚至不明白api里的conte ...
- Backbone学习笔记一Backbone中的MVC
原文章地址http://bigdots.github.io/2015/12/01/Backbone学习笔记(一)/#more Backbone.js为复杂WEB应用程序提供模型(models).集合( ...
- APPCAN学习笔记004---AppCan与Hybrid,appcan概述
APPCAN学习笔记004---AppCan与Hybrid,appcan概述 技术qq交流群:JavaDream:251572072 本节讲了appcan的开发流程,和开发工具 笔记不做具体介绍了,以 ...
- Angularjs学习笔记《一》
开始慢慢的学习新的框架,Angularjs,其中原理不知深浅,但有例子练习,慢慢熟知.看的英文文档一点点翻译学习. 第一个例子,写一个增加,选中,删除的例子, 首先要引进所用的框架源码,这样引进,下面 ...
- Backbone学习笔记 - View篇
Backbone是一种Web端的MVC框架,这里纪录学习Model,View和Collection的笔记. 1 View initialize构造函数 Backbone.View 与jQuery库紧密 ...
- 从直播编程到直播教育:LiveEdu.tv开启多元化的在线学习直播时代
2015年9月,一个叫Livecoding.tv的网站在互联网上引起了编程界的注意.缘于Pingwest品玩的一位编辑在上网时无意中发现了这个网站,并写了一篇文章<一个比直播睡觉更奇怪的网站:直 ...
- Angular2学习笔记(1)
Angular2学习笔记(1) 1. 写在前面 之前基于Electron写过一个Markdown编辑器.就其功能而言,主要功能已经实现,一些小的不影响使用的功能由于时间关系还没有完成:但就代码而言,之 ...
- ABP入门系列(1)——学习Abp框架之实操演练
作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...
- 消息队列——RabbitMQ学习笔记
消息队列--RabbitMQ学习笔记 1. 写在前面 昨天简单学习了一个消息队列项目--RabbitMQ,今天趁热打铁,将学到的东西记录下来. 学习的资料主要是官网给出的6个基本的消息发送/接收模型, ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
随机推荐
- 「Poetize7」电话线路
描述 每台电话都有一个独一无二的号码,用一个十位的十进制数字串表示.电话a和b之间能直接通信,当且仅当“a与b之间仅有一个数字不同”,或者“交换a的某 两位上的数字后,a与b相同”.而a.b之间建立通 ...
- super返回不过来
class Fruit { String color = "未确定颜色"; //定义一个方法,该方法返回调用该方法的实例 public Fruit getT ...
- 数位DP:SPOJ KPSUM - The Sum
KPSUM - The Sum One of your friends wrote numbers 1, 2, 3, ..., N on the sheet of paper. After that ...
- 如何在IIS6,7中部署ASP.NET网站
http://www.cnblogs.com/fish-li/archive/2012/02/26/2368989.html 阅读目录 开始 查看web.config文件 在IIS中创建网站 IIS6 ...
- 配置Chrome启动参数支持本地AJAX请求,解决XMLHttpRequest cannot load file..,Uncaught NetworkError: Failed to execute 'send' on 'XMLHttpRequest':.. 问题
直接将本地的HTML文件拖拽到Chrome浏览器中运行时,发送的AJAX请求本地文件,会报跨域错误: 报错的原因是:Chrome默认不支持本地的AJAX请求! 解决问题的办法是:给Chrome浏览器添 ...
- hdu 3357 水题
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3357 #include <cstdio> #include <cmath> # ...
- phantomjs截图的实践
年前也做了一些东西,由于过年只顾疯了,也没有整理,年后补上把~ 今天整理一下个phantomjs截图实践中遇到的问题. 最近做的一个项目,需要在首页展示已经做的一些项目的缩 ...
- 图解向hadoop分布式文件系统写文件的工作流程
网上看到一张关于hadoop分布式文件系统(hdfs)的工作原理的图片,其实主要是介绍了向hdfs写一个文件的流程.图中的流程已经非常清晰,直接上图 好吧,博客园告诉我少于200字的文章不允许发布到网 ...
- winform程序中将控件置于最顶层或最底层的方法
有时,我们可能动态的添加控件,并准备将其置于对顶层或最底层.实现的方法有两个: 一种方法是在WinForm窗体中使用Controls控件集的SetChildIndex方法,该方法将子控件设定为指定的索 ...
- Python之路,Day13-----暂无正在更新中
Python之路,Day13-----暂无正在更新中