javascript - js中如何實現(xiàn)靜態(tài)變量
問題描述
<button type='button' onclick='func();'>按鈕</button>var i = 0;func(){ i += 1; console.log(i)}
需求:點擊按鈕變量自增1。求最好的實現(xiàn)方法。補充一下,實現(xiàn)方法有很多。
直接保存到全局變量里——污染了全局命名空間
使用一個全局?jǐn)?shù)組保存當(dāng)前app的全局變量——不符合當(dāng)前架構(gòu)
閉包——似乎不適應(yīng)當(dāng)前場景(使用onclick觸發(fā)函數(shù))
停靠到html元素中——還是很low
使用一個大的匿名函數(shù)延長變量的生命周期——不符合當(dāng)前架構(gòu)
問題解答
回答1:誰說閉包不適用?
var func = (function(){var i = 0;return function(){ i++; console.log(i);}}());
或者你可以這樣:
var func = function(){ func.i++; console.log(func.i);};func.i = 0;回答2:
保存在dom節(jié)點屬性中
<button data-click-number='0' type='button' >按鈕</button>
$('#incBtn').on(’click’,function(){ var preClickNumber=$(this).attr(’data-click-number’) ?: 1; $(this).attr(’data-click-number’,preClickNumber++);});回答3:
js沒有靜態(tài)變量。 只有局部變量與全局變量。
<button type='button' onclick='++i'>按鈕</button>var i = 0;回答4:
難道不是用let?
回答5:閉包大發(fā)好,建議題主去看看javascript的函數(shù)式的一些書籍,這也是JavaScript的一大特色
let click = (() => { var i = 0; return function() { i += 1; console.log(i) }})()
相關(guān)文章:
1. javascript - 使用node如何進(jìn)行前后臺分離?2. javascript - 圖片請求失敗怎么去掉左上角的小圖標(biāo)?3. javascript - web端請求一個正在被修改的文件會怎么樣?4. java - 怎樣才算是一個內(nèi)部類5. vue ajax請求回來的數(shù)據(jù)沒有渲染到頁面6. javascript - node.js中stat() access() open() readFile()都能判斷文件是否存在?7. java - 為什么我的延遲隊列取不出數(shù)據(jù)了?8. java - 關(guān)于aop在controller不起用的問題9. javascript - html中select怎么根據(jù)后臺傳來的值選中不同的選項值10. java - 顯示的時間能不能去掉毫秒
