色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

javascript - js中如何實現靜態變量

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

問題描述

<button type='button' onclick='func();'>按鈕</button>var i = 0;func(){ i += 1; console.log(i)}

需求:點擊按鈕變量自增1。求最好的實現方法。補充一下,實現方法有很多。

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

使用一個全局數組保存當前app的全局變量——不符合當前架構

閉包——似乎不適應當前場景(使用onclick觸發函數)

停靠到html元素中——還是很low

使用一個大的匿名函數延長變量的生命周期——不符合當前架構

問題解答

回答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節點屬性中

<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沒有靜態變量。 只有局部變量與全局變量。

<button type='button' onclick='++i'>按鈕</button>var i = 0;回答4:

難道不是用let?

回答5:

閉包大發好,建議題主去看看javascript的函數式的一些書籍,這也是JavaScript的一大特色

let click = (() => { var i = 0; return function() { i += 1; console.log(i) }})()

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 欧美一区二区精品系列在线观看 | 亚洲在线观看免费 | 中文字幕亚洲另类天堂 | 91精品国产免费久久国语蜜臀 | 日韩亚洲精品不卡在线 | 中文字幕一区二区在线观看 | 精品国产日韩久久亚洲 | 夜色精品国产一区二区 | 久久中文字幕免费视频 | 一区二区三区视频在线观看 | 成人亚洲国产精品久久 | 99久久国产综合精品五月天 | 国产精品免费一区二区三区四区 | 免费黄色三级网站 | 欧美多人三级级视频播放 | 欧美白人猛性xxxxx交69 | 国产午夜不卡在线观看视频666 | 亚洲精品日韩一区二区 | 99国产福利视频在线观看 | 欧美一级高清免费播放 | 杨幂丝袜国产福利视频 | 国产高清视频在线播放 | 第一区免费在线观看 | 成人18在线视频播放 | 欧美成人亚洲欧美成人 | 久久黄色毛片 | 成人毛片视频免费网站观看 | 欧美午夜性春猛交 | 国产香蕉国产精品偷在线观看 | 高清性色生活片久久久 | 精品欧美成人高清视频在线观看 | 波多野一区二区三区在线 | 欧美野外性k8播放性迷宫 | 免费看国产精品久久久久 | 全部在线美女网站免费观看 | 日韩在线看片中文字幕不卡 | 99re伊人 | 欧美激情视频一级视频一级毛片 | 手机看片日韩日韩韩 | 免费乱淫视频 | 全部毛片 |