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获取网页中的js、css、Flash等文件
Dec 20 Javascript
javascript使用正则表达式检测IP地址
Dec 03 Javascript
JavaScript常用的返回,自动跳转,刷新,关闭语句汇总
Jan 13 Javascript
jQuery复制表单元素附源码分享效果演示
Sep 30 Javascript
AngularJS中$interval的用法详解
Feb 02 Javascript
jQuery弹出遮罩层效果完整示例
Sep 13 Javascript
javascript中对象的定义、使用以及对象和原型链操作小结
Dec 14 Javascript
Angular 4依赖注入学习教程之简介(一)
Jun 04 Javascript
Javascript实现基本运算器
Jul 15 Javascript
解决bootstrap中下拉菜单点击后不关闭的问题
Aug 10 Javascript
js实现全选反选不选功能代码详解
Apr 24 Javascript
快速解决Vue、element-ui的resetFields()方法重置表单无效的问题
Aug 12 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文章内容分页并生成相应的htm静态页面代码
2010/06/07 PHP
PHP实现类似于C语言的文件读取及解析功能
2017/09/01 PHP
ThinkPHP like模糊查询,like多匹配查询,between查询,in查询,一般查询书写方法
2018/09/26 PHP
PHP扩展Swoole实现实时异步任务队列示例
2019/04/13 PHP
JavaScript 快捷键设置实现代码
2009/03/13 Javascript
JavaScript 事件对象的实现
2009/07/13 Javascript
jquery全选checkBox功能实现代码(取消全选功能)
2013/12/10 Javascript
Jquery插件分享之气泡形提示控件grumble.js
2014/05/20 Javascript
javascript事件委托的用法及其好处简析
2016/04/04 Javascript
jQuery实现内容定时切换效果完整实例
2016/04/06 Javascript
简单的分页代码js实现
2016/05/17 Javascript
js鼠标单击和双击事件冲突问题的快速解决方法
2016/07/11 Javascript
Bootstrap实现带暂停功能的轮播组件(推荐)
2016/11/25 Javascript
详解js静态资源文件请求的处理
2017/08/01 Javascript
jQuery超简单遮罩层实现方法示例
2018/09/06 jQuery
使用vue-router与v-if实现tab切换遇到的问题及解决方法
2018/09/07 Javascript
微信小程序自定义单项选择器样式
2019/07/25 Javascript
vue3使用vue-count-to组件的实现
2020/12/25 Vue.js
用Python制作检测Linux运行信息的工具的教程
2015/04/01 Python
python+opencv实现动态物体识别
2018/01/09 Python
Python基于property实现类的特性操作示例
2018/06/15 Python
python3 实现一行输入,空格隔开的示例
2018/11/14 Python
Centos部署django服务nginx+uwsgi的方法
2019/01/02 Python
Python学习笔记之错误和异常及访问错误消息详解
2019/08/08 Python
Django模板导入母版继承和自定义返回Html片段过程解析
2019/09/18 Python
css3中背景尺寸background-size详解
2014/09/02 HTML / CSS
深入浅析css3 border-image边框图像详解
2015/11/24 HTML / CSS
加拿大约会网站:EliteSingles.ca
2018/01/12 全球购物
如何处理简单的PHP错误
2015/10/14 面试题
个人培训自我鉴定
2014/03/28 职场文书
2014年乡镇团委工作总结
2014/12/18 职场文书
三八红旗手事迹材料
2014/12/26 职场文书
农业项目投资意向书
2015/05/09 职场文书
《世界多美呀》教学反思
2016/02/22 职场文书
导游经典开场白——导游词
2019/04/17 职场文书
JavaScript parseInt0.0000005打印5原理解析
2022/07/23 Javascript