Heim  >  Fragen und Antworten  >  Hauptteil

javascript – So implementieren Sie statische Variablen in js

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

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

Voraussetzung: Klicken Sie auf die Schaltfläche Variable, um sie um 1 zu erhöhen. Finden Sie den besten Weg, dies zu erreichen.
Darüber hinaus gibt es viele Möglichkeiten, dies zu erreichen.

  1. Direkt in globale Variablen speichern – dadurch wird der globale Namensraum verschmutzt

  2. Verwenden Sie ein globales Array, um die globalen Variablen der aktuellen App zu speichern – entspricht nicht der aktuellen Architektur

  3. Schließung – scheint sich nicht an die aktuelle Szene anzupassen (verwenden Sie Onclick, um die Funktion auszulösen)

  4. An HTML-Element angedockt – immer noch sehr niedrig

  5. Die Verwendung einer großen anonymen Funktion zur Verlängerung der Lebensdauer einer Variablen – entspricht nicht der aktuellen Architektur

天蓬老师天蓬老师2671 Tage vor794

Antworte allen(5)Ich werde antworten

  • 某草草

    某草草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;

    Antwort
    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++);
    });

    Antwort
    0
  • 过去多啦不再A梦

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

    js没有静态变量。 只有局部变量与全局变量。

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

    Antwort
    0
  • 大家讲道理

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

    难道不是用let

    Antwort
    0
  • 黄舟

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

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

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

    Antwort
    0
  • StornierenAntwort