账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    学习设计模式中遇到的关于闭包的问题
    22
    0

    问题描述

    在阅读《JS设计模式与开发实践》中单例模式中闭包时候的调用,这两种函数调用有什么区别?为什么会一个正确,一个错误。

    相关代码

    var createLoginLayer = function() {
      instance = document.createElement('div')
      instance.innerHTML = '我是登录浮窗'
      instance.style.display = 'none'
      document.body.appendChild(instance)
      return instance
    }
    
    var getSingle = function(fn) {
      var result
      return function() {
        if (!result) {
          result = fn.apply(this, arguments)
        }
        return result
      }
    }
    
    var createSingle = getSingle(createLoginLayer)
    
    document.getElementById('loginBtn').onclick = function() {
      var dom = createSingle() // 正常,创建一个div,符合预期
      // var dom = getSingle(createLoginLayer)() // 创建多个 div
      dom.style.display = 'block'
    }
    

    预期

    无论点击多少次,都只会创建一个 div

    0
    打赏
    收藏
    点击回答
    您的回答被采纳后将获得:提问者悬赏的 10 元积分
        全部回答
    • 0
    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部