位置: 编程技术 - 正文
推荐整理分享深入理解JavaScript系列(49):Function模式(上篇)(深入理解javascript特性),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:深入理解javascript,深入理解计算机系统,深入理解新发展理念,深入理解新发展理念,推进供给侧结构性改革,深入理解javascript特性,深入理解新发展理念,推进供给侧结构性改革,深入理解javascript特性.pdf,深入理解javascript,内容如对您有帮助,希望把文章链接给更多的朋友!
介绍
本篇主要是介绍Function方面使用的一些技巧(上篇),利用Function特性可以编写出很多非常有意思的代码,本篇主要包括:回调模式、配置对象、返回函数、分布程序、柯里化(Currying)。
回调函数
在JavaScript中,当一个函数A作为另外一个函数B的其中一个参数时,则函数A称为回调函数,即A可以在函数B的周期内执行(开始、中间、结束时均可)。
举例来说,有一个函数用于生成node有一个findNodes函数声明用于查找所有的节点,然后通过callback回调进行执行代码。
关于callback的定义,我们可以事先定义好来用:
也可以直接在调用的时候使用匿名定义,如下:我们平时用的最多的,估计就数jQuery的ajax方法的调用了,通过在done/faild上定义callback,以便在ajax调用成功或者失败的时候做进一步处理,代码如下(本代码基于jquery1.8版):
配置对象
如果一个函数(或方法)的参数只有一个参数,并且参数为对象字面量,我们则称这种模式为配置对象模式。例如,如下代码:则在addPerson内部,就可以随意使用conf的值了,一般用于初始化工作,例如jquery里的ajaxSetup也就是这种方式来实现的:
另外,很多jquery的插件也有这种形式的传参,只不过也可以不传,不传的时候则就使用默认值了。
返回函数
返回函数,则是指在一个函数的返回值为另外一个函数,或者根据特定的条件灵活创建的新函数,示例代码如下:或者你可以利用闭包的特性,在setup函数里记录一个私有的计数器数字,通过每次调用来增加计数器,代码如下:
偏应用
这里的偏应用,其实是将参数的传入工作分开进行,在有的时候一系列的操作可能会有某一个或几个参数始终完全一样,那么我们就可以先定义一个偏函数,然后再去执行这个函数(执行时传入剩余的不同参数)。
举个例子,代码如下:
使用方式如下:如果觉得partialAny._太长,可以用__代替哦。这样使用,就简洁多了吧。
Currying
Currying是函数式编程的一个特性,将多个参数的处理转化成单个参数的处理,类似链式调用。
举一个简单的add函数的例子:这样调用方式就可以有多种了,比如:接下来,我们来定义一个比较通用的currying函数:
这样,我们就可以随意定义我们的业务行为了,比如定义加法:使用方式,真实多种多样哇。如下是减法的例子或者如果你想交换参数的顺序,你可以这样定义
总结
JavaScript里的Function有很多特殊的功效,可以利用闭包以及arguments参数特性实现很多不同的技巧,下一篇我们将继续介绍利用Function进行初始化的技巧。
深入理解JavaScript系列():对象创建模式(下篇) 介绍本篇主要是介绍创建对象方面的模式的下篇,利用各种技巧可以极大地避免了错误或者可以编写出非常精简的代码。模式6:函数语法糖函数语法糖
深入理解JavaScript系列():面向对象编程之ECMAScript实现 介绍本章是关于ECMAScript面向对象实现的第2篇,第1篇我们讨论的是概论和CEMAScript的比较,如果你还没有读第1篇,在进行本章之前,我强烈建议你先读一
JavaScript中的关联数组问题 varbeatles=["john","Paul","George","Ringo"];上面中的beatles数组是个传统数组典型的例子:每个元素的下标是一个数字,每增加一个元素,这个数字就依次增加1。
标签: 深入理解javascript特性
本文链接地址:https://www.jiuchutong.com/biancheng/382873.html 转载请保留说明!上一篇:深入探讨javascript中的数据类型(深入探讨近义词)
下一篇:深入理解JavaScript系列(48):对象创建模式(下篇)(深入理解中国式现代化)
友情链接: 武汉网站建设