map、filter、forEach、reduce数组方法的封装
1、map方法的封装
Array.prototype.mapAlley = function(callback){
//获取调用mapAlley这个方法的数组
let arr = this;
//获取this的指向,如果传递了就获取arguments中的第一个值 没有不存在则this仍然指向window
let _this = arguments[1] || window;
//因为mapAlley是不会操作原数组因此需要返回一个新的数组
var newArr = []
//遍历数据
for(var i=0;i<arr.length;i++){
//将callback的返回值添加到数组中去
newArr.push(callback.call(_this,arr[i],i,arr))
}
return newArr;
}
2、filter方法的封装
Array.prototype.filterAlley = function(callback){
//获取调用filter的数组
let arr = this;
//判断是否传递了第二个参数
let _this = arguments[1] || window;
//因为不会操作原数组因此需要返回一个新的数组
let newArr = [];
for(var i=0;i<arr.length;i++){
//根据callback的返回值(true)来判断当前数据是否使用
if(callback.call(_this,arr[i],i,arr)){
newArr.push(arr[i])
}
}
return newArr;
}
3、forEach方法的封装
Array.prototype.forEachAlley = function(callback){
let arr = this;
let _this = arguments[1] ||window;
for(var i=0;i<arr.length;i++){
callback.call(_this,arr[i],i,arr)
}
}
4、reduce方法的封装及使用
Array.prototype.reduceAlley = function(callback,initVal){
//获取数组
var arr = this;
//判断用户是否传递了初始值
var isInitValFlag = false;
//最终要返回的数据
var prev;
//如果用户传递了初始值
if(initVal){
//则将初始值赋值给prev,并且将isInitValFlag更改为true
prev = initVal;
isInitValFlag = true;
}
for(var i=0;i<arr.length;i++){
//判断初始值是否传递了 如果没有传值则将数组的第一个值定义为初始值
if(isInitValFlag){
prev = callback(prev,arr[i],i,arr);
}else{
prev = arr[i];
isInitValFlag = true;
}
}
return prev;
}
判断数组中的最大值
var arr = [1,2,3,4,5];
arr.reduce((prev,curr)=>{
return Math.max(prev,curr)
})
实现扁平化数组
var arr = [[1,2],[3,4],[5,6,[7,8]]]
function mapArr(arr){
return arr.reduce((prev,curr)=>{
return prev.concat(Array.isArray(curr)?mapArr(curr):curr)
},[])
}
如何获取url地址中的参数
var url = "http://www.baidu.com?name=alley&age=19";
var str = url.slice(url.indexOf("?")+1);
str.split("&").reduce(function(prev,curr){
var key = curr.split("=")[0];
var val = curr.split("=")[1];
prev[key] = val;
return prev
},{})
map、filter、forEach、reduce数组方法的封装的更多相关文章
- Map,Filter和Reduce
转自:https://www.aliyun.com/jiaocheng/444967.html?spm=5176.100033.1.13.xms8KG 摘要:Map,Filter和Reduce三个函数 ...
- Python Map, Filter and Reduce
所属网站分类: python基础 > 函数 作者:慧雅 原文链接: http://www.pythonheidong.com/blog/article/21/ 来源:python黑洞网 www. ...
- [译]PYTHON FUNCTIONS - MAP, FILTER, AND REDUCE
map, filter, and reduce Python提供了几个函数,使得能够进行函数式编程.这些函数都拥有方便的特性,他们可以能够很方便的用python编写. 函数式编程都是关于表达式的.我们 ...
- Map, filter and reduce
To add up all the numbers in a list, you can use a loop like this: Total is initialized to 0. Each t ...
- js Array 中的 map, filter 和 reduce
原文中部分源码来源于:JS Array.reduce 实现 Array.map 和 Array.filter Array 中的高阶函数 ---- map, filter, reduce map() - ...
- Python之内建函数Map,Filter和Reduce
Python进阶 map,filter, reduce是python常用的built-in function. 且常与lambda表达式一起用. 其中: map 形式:map(function_to_ ...
- Go 通过 Map/Filter/ForEach 等流式 API 高效处理数据
什么是流处理 如果有 java 使用经验的同学一定会对 java8 的 Stream 赞不绝口,极大的提高了们对于集合类型数据的处理能力. int sum = widgets.stream() .fi ...
- python库函数Map, Filter and Reduce的用法
python中有三个函数式编程极大的简化了程序的复杂性,这里就做一下讨论和记录. 一 Map:应用在链表输入所有元素的函数,它的格式如下所示: map(function_to_apply, list_ ...
- [Python学习笔记-002] lambda, map, filter and reduce
1. lambda lambda, 即匿名函数,可以理解为跟C语言的宏类似.例如: >>> max = lambda x, y: x if x > y else y >& ...
随机推荐
- Machine Learning 之一,什么是机器学习。
Machine Learning 机器学习,什么是机器学习.我觉得尚学堂的培训老师讲的很不错,就是两个字来介绍.------拟人. 就是模拟人类的思维方式. 老师举的例子: 和女朋友约会,第一次约会, ...
- (转载)理解和使用Promise.all和Promise.race
声明:本文转载自:https://www.jianshu.com/p/7e60fc1be1b2 一.Pomise.all的使用 Promise.all可以将多个Promise实例包装成一个新的Prom ...
- angularJS 上传multipart/form-data
var fd = new FormData();fd.append('file', vm.file);CommodityViewImport.post(fd, onSaveSuccess, onSav ...
- autocad 2015 破解方法
下载 http://trial.autodesk.com/SWDLDNET4/2015/ACD/DLM/AutoCAD_2015_Simplified_Chinese_Win_64bit_dlm.sf ...
- 8、如何实现可迭代对象和迭代器对象 9、如何使用生成器函数实现可迭代对象 10、如何进行反向迭代以及如何实现反向迭代 11、如何对迭代器做切片操作 12、如何在一个for语句中迭代多个可迭代对象
8.如何实现可迭代对象和迭代器对象 PS:注意重载Iterator方法的时候,需要和原来的方法名一样,否则创建实例时会报错 from collections import Iterator,Itera ...
- 微信小程序开发入门与实践
基础知识---- MINA 框架 为方便微信小程序开发,微信为小程序提供了 MINA 框架,这套框架集成了大量的原生组件以及 API.通过这套框架,我们可以方便快捷的完成相关的小程序开发工作. MIN ...
- 什么是URI、URL、URN、URC和Data URI?
前言 不知道大家有没有电话拨号通过'猫'上网的经历,那时测试网络是否连接,最好的方式就是打开浏览器输入: www.baidu.com 那会管这一连串字母叫' 网址 '.之后上大学(计算机专业),知道了 ...
- 微信小程序picker下拉绑定数据
页面部分 <picker mode = "selector" bindchange="bindPickerChange" value="{{pr ...
- 基于用户的协同过滤(UserCF)
- 在当前对象中可以使用this关键字指代当前对象
在当前对象中可以使用this关键字指代当前对象