zoukankan      html  css  js  c++  java
  • 惰性函数

    外国网址乱逛发现的,一种非常高效的写法,用于存储需要经过非常复杂计算得出的变量。原文的例子与我的有点出入。

    经典的写法,利用上层作用域的变量储存它。缺点如下,好容易暴露成全局变量,造成管理混乱,并且每次执行都要判断分支条件if(t)是否返回true。

    模块模式,就是把第一方法全部封进闭包中,这样就不污染全局变量。还是保留判断分支条件的缺点。

    利用函数也是一种对象,把参数当做它的键,计算得到的值为它的值。比上面的直观,但一样要判断分支条件。

    惰性函数。这才是正点。第一次计算得到的值,供内部函数调用,然后用这个内部函数重置外部函数(因为同名),以后就不用计算了,也不用判断分支条件。这时函数就相当于一个被赋值的变量!

            dom.feature.bodyOffsetNotIncludeMargin = function(){
                var el = dom.body(),//DOM树遍历操作
                result = parseFloat(dom.getStyle(el,"margin-top"))!== el.offsetTop;//复杂的比较运算
                dom.feature.bodyOffsetNotIncludeMargin = function(){
                    return result;//缓存结果,第一次之后直接返回,再不用计算;
                }
                return result;//第一次执行结果
            }
    
  • 相关阅读:
    腾讯开源 APIJSON 连创五个第一
    最火的分布式 HTAP 数据库 TiDB
    完爆Facebook/GraphQL,APIJSON全方位对比解析(三)-表关联查询
    后端自动化版本管理,再也不用改URL了!
    后端开挂:3行代码写出8个接口!
    3步创建服务端新表及配置
    Activity猫的一生-故事解说Activity生命周期
    APIJSON-以坚持和偏执,回敬傲慢和偏见
    APIJSON,让接口和文档见鬼去吧!
    Android 100多个Styles快速开发布局XML,一行搞定View属性,一键统一配置UI...
  • 原文地址:https://www.cnblogs.com/rubylouvre/p/1593094.html
Copyright © 2011-2022 走看看