Heim > Fragen und Antworten > Hauptteil
<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.
Direkt in globale Variablen speichern – dadurch wird der globale Namensraum verschmutzt
Verwenden Sie ein globales Array, um die globalen Variablen der aktuellen App zu speichern – entspricht nicht der aktuellen Architektur
Schließung – scheint sich nicht an die aktuelle Szene anzupassen (verwenden Sie Onclick, um die Funktion auszulösen)
An HTML-Element angedockt – immer noch sehr niedrig
Die Verwendung einer großen anonymen Funktion zur Verlängerung der Lebensdauer einer Variablen – entspricht nicht der aktuellen Architektur
某草草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;
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++);
});
过去多啦不再A梦2017-06-26 11:00:14
js没有静态变量。 只有局部变量与全局变量。
<button type="button" onclick="++i">按钮</button>
var i = 0;
黄舟2017-06-26 11:00:14
闭包大发好,建议题主去看看javascript的函数式的一些书籍,这也是JavaScript的一大特色
let click = (() => {
var i = 0;
return function() {
i += 1;
console.log(i)
}
})()