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

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

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

瀏覽:109日期: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
相關文章:
主站蜘蛛池模板: 国产专区在线 | 日日碰碰 | 99亚洲综合| 国产精品毛片久久久久久 | 亚洲精品小视频在线观看 | 秋霞在线一区 | 中文字幕高清av | 成人3d动漫一区二区三区91 | 日本免费一区二区三区四区 | 夜久久 | 日韩欧美三级 | aaa天堂| 久久蜜桃资源一区二区老牛 | 成人精品国产一区二区4080 | 国产成人精品一区二区三区在线 | 91亚洲国产亚洲国产 | 久久精品国产一区 | 欧美中文字幕一区二区三区亚洲 | 成人做爰www免费看视频网站 | 亚洲免费视频一区二区 | 亚洲黄色成人网 | 亚洲精品美女在线观看 | 日本不卡高字幕在线2019 | 精品久久久久久18免费网站 | 免费一级淫片aaa片毛片a级 | 性欧美精品一区二区三区在线播放 | 精品国产91乱码一区二区三区 | 日韩av成人 | 一级全黄少妇性色生活免费看 | 欧美 日韩 亚洲91麻豆精品 | 夜夜草天天草 | 国产精品久久久久久久久久 | 欧美中文字幕一区 | 日本久久综合 | 亚洲一区亚洲二区 | 国产精品精品视频一区二区三区 | 亚洲在线一区二区 | 亚洲国产成人精品久久 | 九九99九九精彩46 | 成人免费大片黄在线播放 | 国产精品视频一区二区三区 |