首页 >社区问答列表 >javascript - js中如何实现静态变量

javascript - js中如何实现静态变量

<button type="button" onclick="func();">按钮</button>

var i = 0;
func(){
    i += 1;
    console.log(i)
}

需求:点击按钮变量自增1。求最好的实现方法。
补充一下,实现方法有很多。

  1. 直接保存到全局变量里——污染了全局命名空间

  2. 使用一个全局数组保存当前app的全局变量——不符合当前架构

  3. 闭包——似乎不适应当前场景(使用onclick触发函数)

  4. 停靠到html元素中——还是很low

  5. 使用一个大的匿名函数延长变量的生命周期——不符合当前架构

  • 某草草
  • 某草草    2017-06-26 11:00:145楼

    谁说闭包不适用?

    var func = (function(){
    var i = 0;
    return function(){
        i++;
        console.log(i);
    }
    
    }());

    或者你可以这样:

    var func = function(){
        func.i++;
        console.log(func.i);
    };
    func.i = 0;

    +0添加回复

  • 回复
  • 小皮
  • 小皮    2017-06-26 11:00:144楼

    保存在dom节点属性中

    <button data-click-number="0" type="button" id="incBtn" >按钮</button>
    $("#incBtn").on('click',function(){
     var preClickNumber=$(this).attr('data-click-number') ?: 1;
     $(this).attr('data-click-number',preClickNumber++);
    });

    +0添加回复

  • 回复
  • 黄舟
  • 黄舟    2017-06-26 11:00:141楼

    闭包大发好,建议题主去看看javascript的函数式的一些书籍,这也是JavaScript的一大特色

    let click = (() => {
        var i = 0;
        return function() {
          i += 1;
          console.log(i)
        }
    })()

    +0添加回复

  • 回复