首頁  >  問答  >  主體

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. 使用一個大的匿名函數來延長變數的生命週期-不符合目前架構

天蓬老师天蓬老师2671 天前797

全部回覆(5)我來回復

  • 某草草

    某草草2017-06-26 11:00:14

    誰說閉包不適用?

    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
  • PHP中文网

    PHP中文网2017-06-26 11:00:14

    保存在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
  • 过去多啦不再A梦

    过去多啦不再A梦2017-06-26 11:00:14

    js沒有靜態變數。 只有局部變數與全域變數。

    <button type="button" onclick="++i">按钮</button>
    
    var i = 0;

    回覆
    0
  • 大家讲道理

    大家讲道理2017-06-26 11:00:14

    不是用let

    回覆
    0
  • 黄舟

    黄舟2017-06-26 11:00:14

    閉包大發好,建議題主去看看javascript的函數式的一些書籍,這也是JavaScript的一大特色

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

    回覆
    0
  • 取消回覆