亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

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

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

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

問題描述

<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)方法有很多。

直接保存到全局變量里——污染了全局命名空間

使用一個全局?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é)點(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沒有靜態(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) }})()

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 视频一区在线观看 | 久久久久国产成人精品亚洲午夜 | 久久福利资源国产精品999 | 国模偷拍在线观看免费视频 | 成人a毛片一级 | 欧美成人精品一区二区三区 | 天天五月天丁香婷婷深爱综合 | 久久w5ww成w人免费不卡 | 亚洲国产系列 | 91精品一区二区三区在线播放 | 免费观看三级毛片 | 久久99久久精品免费思思 | 大片毛片| 欧美一级特黄做 | 中文字幕高清在线天堂网 | 久久99毛片免费观看不卡 | 欧美激情视频一区二区免费 | 欧美日本一区 | 欧美高清视频在线 | 亚洲精品高清国产一久久 | 中文字幕精品在线观看 | 99视频一区| 欧美成人极品怡红院tv | 国产玖玖在线 | 男女免费观看在线爽爽爽视频 | 99久久精品免费看国产免费软件 | 成人91在线 | 在线看国产视频 | 欧美精品高清在线观看 | 国产在线观看第一页 | a级毛片在线观看 | 国产成人亚洲精品影院 | 成人免费大片黄在线观看com | 在线观看日本免费视频大片一区 | 亚洲欧美高清在线 | 亚洲精品一区专区 | 理论片中文字幕 | 久久精品亚洲乱码伦伦中文 | 日本欧美韩国一区二区三区 | 26uuu欧美日韩国产 | 日本xxxxx黄区免费看动漫 |