javascript - js中如何實(shí)現(xiàn)靜態(tài)變量
問(wèn)題描述
<button type='button' onclick='func();'>按鈕</button>var i = 0;func(){ i += 1; console.log(i)}
需求:點(diǎn)擊按鈕變量自增1。求最好的實(shí)現(xiàn)方法。補(bǔ)充一下,實(shí)現(xiàn)方法有很多。
直接保存到全局變量里——污染了全局命名空間
使用一個(gè)全局?jǐn)?shù)組保存當(dāng)前app的全局變量——不符合當(dāng)前架構(gòu)
閉包——似乎不適應(yīng)當(dāng)前場(chǎng)景(使用onclick觸發(fā)函數(shù))
停靠到html元素中——還是很low
使用一個(gè)大的匿名函數(shù)延長(zhǎng)變量的生命周期——不符合當(dāng)前架構(gòu)
問(wèn)題解答
回答1:誰(shuí)說(shuō)閉包不適用?
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é)點(diǎn)屬性中
<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沒(méi)有靜態(tài)變量。 只有局部變量與全局變量。
<button type='button' onclick='++i'>按鈕</button>var i = 0;回答4:
難道不是用let?
回答5:閉包大發(fā)好,建議題主去看看javascript的函數(shù)式的一些書(shū)籍,這也是JavaScript的一大特色
let click = (() => { var i = 0; return function() { i += 1; console.log(i) }})()
相關(guān)文章:
1. javascript - position fixed;設(shè)置了height 100 卻不是瀏覽器可視窗口的寬高,求大神釋疑。2. mysql 5個(gè)left關(guān)鍵 然后再用搜索條件 幾千條數(shù)據(jù)就會(huì)卡,如何解決呢3. javascript - 為什么在谷歌控制臺(tái) 輸出1的時(shí)候,輸出的1立馬就不見(jiàn)了4. android - 微信的安裝包在只編譯了armeabi,沒(méi)有armeabi-v7a,arm64-v8a,x86是如何運(yùn)行在各種處理器的手機(jī)上的?5. javascript - webpack 分割加載代碼后,react 界面不更新6. javascript - 小程序中遇到j(luò)s執(zhí)行時(shí)序問(wèn)題7. javascript - js刪除頁(yè)面節(jié)點(diǎn)有何作用,直接刪除具體代碼不是一樣的效果么?8. python3.x - git bash如何運(yùn)行.bat文件?9. 按照本節(jié)給的代碼“膽小如鼠”并不能變成紅色10. mysql 字段索引的問(wèn)題
