av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

javascript - js中如何實(shí)現(xiàn)靜態(tài)變量

瀏覽:129日期:2023-05-13 10:42:59

問(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) }})()

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 中国免费毛片 | 欧美成人激情视频 | 成人在线视频观看 | 日韩在线成人 | 一级片观看 | 欧美精品www | av大片在线观看 | 日本三级中文字幕 | 噜噜视频 | 国产成人综合网 | 一区二区三区国产精品 | 欧美超碰在线 | 波多野结衣av在线播放 | 午夜在线 | aaaaaa毛片 | 欧美精品第一页 | 超碰在线网站 | √天堂资源地址在线官网 | 国产亚洲欧洲 | 亚洲一区二区久久 | 亚洲国产成人在线 | 三年中文在线看免费观看 | 久久九九99 | av网站观看 | 久久日韩精品 | 欧美午夜精品一区二区 | 久热精品在线 | 日本一级片在线观看 | 精品国产一区二区三区久久久蜜月 | 91插插插插插 | 成人深夜视频 | 91av视频| 99伊人| 欧美xxxx网站| 欧美久久久久 | 亚洲一区二区在线播放 | 蜜桃久久久 | 欧美性猛交xxxx免费看久久久 | 日本久久精品视频 | 乳大翘臀1v1h糙汉 | 99视频|