作家
登录

惰性函数定义模式 使用方法第1/3页

作者: 来源:www.28hudong.com 2013-03-30 03:16:37 阅读 我要评论

这篇文章阐述的是一种函数式编程(functional-programming)设计模式,我称之为惰性函数定义(Lazy Function Definition)。我不止一次发现这种模式在JavaScript中大有用处,尤其是编写跨浏览器的、高效运行的库之时。 热身问题 编写一个函数foo,它返回的是Date对象,这个对象保存的是foo首次调用的时间。 方法一:上古时代的技术 这个最简陋的解决方案使用了全局变量t来保存Date对象。foo首次调用时会把时间保存到t中。接下来的再次调用,foo只会返回保存在t中的值。 复制代码 代码如下:var t; function foo() { if (t) { return t; } t = new Date(); return t; } 但是这样的代码有两个问题。第一,变量t是一个多余的全局变量,并且在 foo调用的间隔期间有可能被更改。第二,在调用时这些代码的效率并没有得到优化因为每次调用 foo都必须去求值条件。虽然在这个例子中,求值条件并不显得低效,但在现实世界的实践例子中常常会有极为昂贵的条件求值,比如在if-else-else-…的结构中。 方法二:模块模式 我们可以通过被认为归功于Cornford 和 Crockford 的模块模式来弥补第一种方法的缺陷。使用闭包可以隐藏全局变量t,只有在 foo内的代码才可以访问它。 复制代码 代码如下:var foo = (function() { var t; return function() { if (t) { return t; } t = new Date(); return t; } })(); 但这仍然没有优化调用时的效率,因为每次调用foo依然需要求值条件。 虽然模块模式是一个强大的工具,但我坚信在这种情形下它用错了地方。 方法三:函数作为对象 由于JavaScript的函数也是对象,所以它可以带有属性,我们可以据此实现一种跟模块模式质量差不多的解决方案。 复制代码 代码如下:function foo() { if (foo.t) { return foo.t; } foo.t = new Date(); return foo.t; } 在一些情形中,带有属性的函数对象可以产生比较清晰的解决方案。我认为,这个方法在理念上要比模式模块方法更为简单。 这个解决方案避免了第一种方法中的全局变量t,但仍然解决不了foo每次调用所带来的条件求值。

  推荐阅读

  百度前台js笔试题与答案

第一题 编写一个方法 求一个字符串的字节长度 第二题 如何控制alert中的换行 第三题 解释document.getElementById("ElementID").style.fontSize="1.5em" 第四题 将一个类似图中的效果分离成css和html 第五题 按照格>>>详细阅读


本文标题:惰性函数定义模式 使用方法第1/3页

地址:http://www.17bianji.com/kaifa2/JS/30059.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)