搜索
首页web前端js教程Javascript 是你的高阶函数(高级应用)_javascript技巧

在通常的编程语言中,函数的参数只能是基本类型或者对象引用,返回值也只是基本数据类型或对象引用。但在Javascript中函数作为一等公民,既可以当做参数传递,也可以被当做返回值返回。所谓高阶函数就是可以把函数作为参数,或者是将函数作为返回值的函数。这两种情形在实际开发中有很多应用场景,本文是我在工作学习中遇到的几种应用场景的总结。

  回调函数

  代码复用是衡量一个应用程序的重要标准之一。通过将变化的业务逻辑抽离封装在回调函数中能够有效的提高代码复用率。比如ES5中为数组增加的forEach方法,遍历数组,对每个元素调用同一个函数。

array = {};
array.forEach = function(arr, fn){
  for (var i = 0, len = arr.length; i < len; i++) {
    fn(arr[i], i, arr);
  }
}

通过回调函数将业务的重点聚焦在回调函数中,而不必每次都要重复编写遍历代码。

  偏函数

  作为将函数当做返回值输出的典型应用就是偏函数。所谓偏函数是指创建一个调用另外一个部分——参数或变量已经预置的函数——的函数的用法。反正看着定义我是没理解这东东干嘛的。咱们还是先看例子吧,偏函数最典型的例子就是类型判断。

  Javascript对象都拥有三个属性:原型属性、类属性、可扩展性。(不知道的同学要回去翻犀牛书哦,page:138)类属性是一个字符串,Javascript中并未直接提供,但我们可以利用Object.prototype.toString来间接得到。该函数总是返回如下形式:

[object Class]  

因此我们可以编写一系列isType函数。

代码如下:

 

isString = function(obj){
  return Object.prototype.toString.call(obj) === "[object String]";
}
isNumber = function(obj){
  return Object.prototype.toString.call(obj) === "[object Number]";
}
isArray = function(obj){
  return Object.prototype.toString.call(obj) === "[object Array]";
}

 这几个函数中大部分代码是重复的,这时高阶函数便华丽丽的登场了:

isType = function(type) {
  return function(obj) {
    return Object.prototype.toString.call(obj) === "[object " + type + "]";
  }
}

isString = isType('String');
isNumber = isType('Number');
isArray = isType('Array');

 所以通过指定部分参数来返回一个新的定制函数的形式就是偏函数。

  currying(柯里化)

  currying又称部分求值。一个currying的函数首先会接受一些参数,接受这些参数之后,函数并不会立即求值,而是继续返回另一个函数,刚才传入的参数在函数形成的闭包中被保存起来。待到函数被真正需要求值的时候,之前传入的所有参数都会被一次性用于求值。

var currying = function(fn) {
  var args = [];
  
  return function() {
    if (arguments.length === 0) {
      return fn.applay(this, args);
    } else {
      args = args.concat(arguments);
      return arguments.callee;
    }
  }
}

假设我们以计算一个月每天花销为例:

var currying = function(fn) {
debugger;
  var args = [];
  
  return function() {
    if (arguments.length === 0) {
      return fn.apply(this, args);
    } else {
      Array.prototype.push.apply(args, arguments);
      return arguments.callee;
    }
  }
}

cost = function(){
  var sum = 0;
  for (var i = 0, len = arguments.length; i < len; i++) {
    sum += arguments[i];
  }
  
  return sum;
}
var cost = currying(cost);

cost(100);
cost(200);
alert(cost())

事件节流

  在某些场景下,某些事件可能会被重复的触发,但事件处理函数并不需要每次都执行。比如在window.resize事件中进行复杂的逻辑计算,如果用户频繁的改变浏览器大小,复杂计算会对性能造成严重影响;有时这些逻辑计算并不需要每次rezise时都触发,只需要计算有限的几次便可以。这时我们需要根据时间段来忽略一些事件请求。请看以下节流函数:

function throttle(fn, interval) {
   var doing = false;

   return function() {
    if (doing) {
     return;
    }
    doing = true;
    fn.apply(this, arguments);
    setTimeout(function() {
     doing = false;
    }, interval);
   }
  }
  
  window.onresize = throttle(function(){
    console.log('execute');
  }, 500);

通过控制函数执行时间,可以在函数执行次数与功能需求之间达到完美平衡。另一个事件是mousemove。如果我们给一个dom元素绑定该事件,鼠标在改元素上移动时,该事件便会重复触发。

  事件结束

  对于某些可以频繁触发的事件,有时候我们希望在事件结束后进行一系列操作。这时我们可以利用高阶函数做如下处理:

 

function debounce(fn, interval) {
  var timer = null;

 function delay() {
  var target = this;
  var args = arguments;
  return setTimeout(function(){
   fn.apply(target, args);
  }, interval);
 }

 return function() {
  if (timer) {
   clearTimeout(timer);
  }

  timer = delay.apply(this, arguments);
 }
};
window.onresize = throttle(function(){
  console.log('resize end');
}, 500);

如果在这一过程中事件被触发则清除上一次事件句柄,重新绑定执行时间。

参考资料:

《深入浅出node》

《Javascript设计模式与开发实践》

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
如何使用PHP进行函数式编程如何使用PHP进行函数式编程Jun 06, 2023 am 08:21 AM

PHP是一种广泛使用的服务器端语言,许多Web开发人员喜欢使用PHP的原因之一是它丰富的函数库和简单易用的函数语法。而函数式编程则是一种程序设计范式,它良好地封装数据和行为,使得代码更加模块化,易于维护和测试。在这篇文章中,我们将介绍如何使用PHP进行函数式编程。函数式编程基础函数式编程的核心思想是将函数视为一等公民,函数本身可以像变量一样被传递、返回和组合

如何在Python中创建高阶函数?如何在Python中创建高阶函数?Sep 05, 2023 pm 07:29 PM

在Python中,将另一个函数作为参数或将函数作为输出返回的函数被称为高阶函数。让我们来看看其特性-该函数可以存储在变量中。该函数可以作为参数传递给另一个函数。高阶函数可以以列表、哈希表等形式存储函数可以从函数中返回。让我们来看一些例子−函数作为对象Example的中文翻译为:示例在这个例子中,这些函数被视为对象。在这里,函数demo()被赋值给一个变量-#Creatingafunctiondefdemo(mystr):returnmystr.swapcase()#swappingthecase

PHP 箭头函数:如何处理高阶函数的嵌套调用PHP 箭头函数:如何处理高阶函数的嵌套调用Sep 13, 2023 am 08:27 AM

PHP箭头函数:如何处理高阶函数的嵌套调用,需要具体代码示例引言:在PHP7.4版本中,引入了箭头函数(arrowfunctions)的概念,箭头函数是一种简洁的写法,能够优雅地处理高阶函数的嵌套调用。本文将介绍箭头函数的基本使用方法,并通过具体代码示例演示如何处理高阶函数的嵌套调用。一、什么是箭头函数?箭头函数是PHP7.4版本引入的新特性,它是一

python高阶函数有哪些python高阶函数有哪些Nov 10, 2023 pm 04:42 PM

高阶函数有map()、filter()、reduce()、lambda函数、partial()等。详细介绍:1、map():这个内置函数接受一个函数和一个或多个可迭代对象作为输入,然后返回一个将输入函数应用于可迭代对象的每个元素的迭代器;2、filter():这个内置函数接受一个函数和一个可迭代对象作为输入,然后返回一个迭代器,该迭代器产生那些使得输入函数返回True的元素等等

在Python中的高阶函数在Python中的高阶函数Sep 13, 2023 pm 06:53 PM

简介Python的高阶函数世界如果您想提高Python编程能力并生成更具表现力和更有效的代码,那么您来对地方了。Python中的函数不仅仅是专门的代码块。它们也是可以移动、转移、甚至动态生成的强大东西。通过处理其他函数,高阶函数增强了这种多功能性。本文将广泛讨论高阶函数的原理。我们将探索作为一流对象的进程的基础知识,深入研究高阶函数的现实世界示例,并鼓励lambda函数的功能以实现清晰而美观的代码。还将讨论函数式编程模型及其在Python中使用时的优点。读完本文后,您将牢牢掌握高阶函数,并且知道

如何理解 Golang 中函数类型的高阶函数?如何理解 Golang 中函数类型的高阶函数?Apr 20, 2024 am 11:54 AM

Golang高阶函数可接受和返回函数。它们分两类:接收函数作为参数:处理其他函数或执行动态程序。返回函数作为返回值:创建和返回可存储和后期执行的函数。

Golang函数的高阶函数应用场景分析Golang函数的高阶函数应用场景分析May 17, 2023 pm 05:40 PM

随着Golang语言的流行和发展,越来越多的开发者开始尝试使用函数式编程的思想。Golang中的高阶函数为函数式编程带来了很大的便利性,并且在实际开发中应用广泛。那么,Golang函数的高阶函数应用场景是什么呢?接下来,我们将对此进行分析。函数参数和返回值的处理在Golang中,函数可以作为其他函数的参数或返回函数。这就意味着我们可以将函数作为一个参数传入另

一篇文章带你了解Python高阶函数一篇文章带你了解Python高阶函数Jul 25, 2023 pm 04:07 PM

高阶函数是在Python中一个非常有用的功能函数,所谓高阶函数就是一个函数可以用来接收另一个函数作为参数,这样的函数叫做高阶函数。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前By尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
1 个月前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
4 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)