JS高阶函数原理与用法实例分析


Posted in Javascript onJanuary 15, 2019

本文实例讲述了JS高阶函数原理与用法。分享给大家供大家参考,具体如下:

如果您正在学习JavaScript,那么您必须遇到高阶函数这个术语。这听起来复杂,其实不然。

使JavaScript适合函数式编程的原因是它接受高阶函数。

高阶函数在JavaScript中广泛使用。如果你已经用JavaScript编程了一段时间,你可能已经使用它们甚至不知道。

要完全理解这个概念,首先必须了解函数式编程是什么一等函数(first-Class Function)以及的概念。

函数式编程

在大多数简单的术语中,函数编程是一种编程形式,您可以将函数作为参数传递给其他函数,并将它们作为值返回。在函数式编程中,我们根据函数思考和编码。

JavaScript,Haskell,Clojure,Scala和Erlang是实现函数式编程的一些语言。

一等函数

如果您一直在学习JavaScript,您可能听说过JavaScript将函数视为一等公民。那是因为在JavaScript或任何其他函数式编程语言中,函数是对象。

在JavaScript中,函数是一种特殊类型的对象。他们是Function对象。

在JavaScript中,您可以使用其他类型(如对象,字符串或数字)执行的所有操作函数都可以执行。您可以将它们作为参数传递给其他函数(回调函数),将它们分配给变量并传递它们等等。这就是JavaScript中的函数被称为First-Class函数(一等函数)的原因。

高阶函数

高阶函数是对其他函数进行操作的函数,可以将它们作为参数或通过返回它们。简单来说,高阶函数是一个函数,它接收函数作为参数或将函数作为输出返回。

例如Array.prototype.mapArray.prototype.filter并且Array.prototype.reduce是一些高阶功能,内置的语言。

运行高阶函数

让我们看一下内置高阶函数的一些例子,看看它与我们不使用高阶函数的解决方案的比较。

Array.prototype.map

map()方法通过调用作为输入数组中每个元素的参数提供的回调函数来创建一个新数组。该map()方法将从回调函数中获取每个返回值,并使用这些值创建一个新数组。

传递给回调函数map()方法接受3个参数:elementindex,和array

假设我们有一个数组,我们想要创建一个新数组,其中包含第一个数组的每个值的两倍。让我们看看如何使用和不使用高阶函数来解决问题。

不用高阶函数

const arr1 = [1,2,3]; 
const arr2 = [];
for(let i = 0; i <arr1.length; i ++){ 
 arr2.push(arr1 [i] * 2); 
}
//打印[2,4,6] 
console.log(arr2);

使用高阶函数

const arr1 = [1,2,3];
const arr2 = arr1.map (function (item) { 
 return item * 2; 
}
console.log(arr2)

我们可以使用箭头函数语法使其更短

const arr1 = [1, 2, 3];
const arr2 = arr1.map(item => item * 2);
console.log(arr2);

创建我们自己的高阶函数

到目前为止,我们看到了语言中内置的各种高阶函数。现在让我们创建自己的高阶函数。

我们假设JavaScript没有原生map方法。我们可以自己构建它,从而创建我们自己的高阶函数。

假设我们有一个字符串数组,我们希望将此数组转换为整数数组,其中每个元素表示原始数组中字符串的长度。

const strArray = ['JavaScript', 'Python', 'PHP', 'Java', 'C'];
function mapForEach(arr, fn) {
 const newArray = [];
 for(let i = 0; i < arr.length; i++) {
 newArray.push(
  fn(arr[i])
 );
 }
 return newArray;
}
const lenArray = mapForEach(strArray, function(item) {
 return item.length;
});
// prints [ 10, 6, 3, 4, 1 ]
console.log(lenArray);

在上面的例子中,我们创建了一个高阶函数mapForEach,它接受一个数组和一个回调函数fn。此函数循环遍历提供的数组,并在每次迭代时调用函数调用fn内的回调函数newArray.push

回调函数fn接收数组的当前元素并返回该元素的长度,该元素存储在newArray。for循环完成后,newArray返回并分配给lenArray。

结论

我们已经了解了高阶函数和一个内置的高阶函数。我们还学习了如何创建自己的高阶函数。

简而言之,高阶函数是一个函数,它可以接收函数作为参数,甚至可以返回一个函数。高阶函数就像常规函数一样,具有接收和返回其他函数的附加能力,即参数和输出。

更多关于JavaScript相关内容可查看本站专题:《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
JavaScript国旗变换效果代码
Aug 13 Javascript
$.ajax json数据传递方法
Nov 19 Javascript
左右悬浮可分组的网站QQ在线客服代码(可谓经典)
Dec 21 Javascript
基于豆瓣API+Angular开发的web App
Jan 02 Javascript
Angularjs中如何使用filterFilter函数过滤
Feb 06 Javascript
Angular实现表单验证功能
Nov 13 Javascript
通过vue-cli3构建一个SSR应用程序的方法
Sep 13 Javascript
angularjs1.5 组件内用函数向外传值的实例
Sep 30 Javascript
vue最简单的前后端交互示例详解
Oct 11 Javascript
GOJS+VUE实现流程图效果
Dec 01 Javascript
微信公众平台 客服接口发消息的实现代码(Java接口开发)
Apr 17 Javascript
layui弹出框Tab选项卡的示例代码
Sep 04 Javascript
JS立即执行函数功能与用法分析
Jan 15 #Javascript
vue-cli 目录结构详细讲解总结
Jan 15 #Javascript
webpack file-loader和url-loader的区别
Jan 15 #Javascript
jQuery+vue.js实现的多选下拉列表功能示例
Jan 15 #jQuery
Element输入框带历史查询记录的实现示例
Jan 15 #Javascript
微信小程序实现多选删除列表数据功能示例
Jan 15 #Javascript
element-ui带输入建议的input框踩坑(输入建议空白以及会闪出上一次的输入建议问题)
Jan 15 #Javascript
You might like
用PHP和Shell写Hadoop的MapReduce程序
2014/04/15 PHP
destoon调用自定义模板及样式的公告栏
2014/06/21 PHP
windows系统php环境安装swoole具体步骤
2021/03/04 PHP
自动更新作用
2006/10/08 Javascript
JavaScript 学习笔记(四)
2009/12/31 Javascript
JQuery从头学起第二讲
2010/07/04 Javascript
js自定义事件及事件交互原理概述(二)
2013/02/01 Javascript
uploadify在Firefox下丢失session问题的解决方法
2013/08/07 Javascript
jQuery prev ~ siblings选择器使用介绍
2013/08/09 Javascript
JQuery中form验证出错信息的查看方法
2013/10/08 Javascript
全面解析DOM操作和jQuery实现选项移动操作代码分享
2016/06/07 Javascript
浅谈JS函数定义方式的区别
2016/10/30 Javascript
Angularjs中的页面访问权限怎么设置
2016/11/11 Javascript
详解获取jq ul第一个li定位的四种解决方案
2016/11/23 Javascript
AngularJS动态菜单操作指令
2017/04/25 Javascript
JS实现微信里判断页面是否被分享成功的方法
2017/06/06 Javascript
10行代码实现微信小程序滑动tab切换
2018/12/28 Javascript
详解Vue中的scoped及穿透方法
2019/04/18 Javascript
wxPython窗口的继承机制实例分析
2014/09/28 Python
Python网络编程中urllib2模块的用法总结
2016/07/12 Python
详解python里使用正则表达式的全匹配功能
2017/10/19 Python
Python+PIL实现支付宝AR红包
2018/02/09 Python
windows下numpy下载与安装图文教程
2019/04/02 Python
Python+selenium点击网页上指定坐标的实例
2019/07/05 Python
python与mysql数据库交互的实现
2020/01/06 Python
python模式 工厂模式原理及实例详解
2020/02/11 Python
Python+OpenCV图像处理——实现直线检测
2020/10/23 Python
html5 canvas绘制矩形和圆形的实例代码
2016/06/16 HTML / CSS
佛罗里达州印第安河新鲜水果:Hale Groves
2017/02/20 全球购物
德国baby-markt婴儿用品瑞士网站:baby-markt.ch
2017/06/09 全球购物
Myprotein俄罗斯官网:欧洲第一运动营养品牌
2019/05/05 全球购物
Claire’s法国:时尚配饰、美容、珠宝、头发
2021/01/16 全球购物
大学生简历求职信
2014/06/24 职场文书
史上最牛辞职信
2015/05/13 职场文书
指导教师推荐意见
2015/06/05 职场文书
党员干部学习心得体会
2016/01/23 职场文书