javascript - js中如何實現靜態變量
問題描述
<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) }})()
相關文章:
1. javascript - 關于css絕對定位在ios瀏覽器被橡皮筋遮擋的問題2. javascript - 請教如何獲取百度貼吧新增的兩個加密參數3. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處4. Python爬蟲如何爬取span和span中間的內容并分別存入字典里?5. javascript - 請問 chrome 為什么會重復加載圖片資源?6. c++ - 請問MySQL_Connection::isReadOnly 怎么解決?7. css3 - 微信前端頁面遇到的transition過渡動畫的bug8. (python)關于如何做到按win+R再輸入文件文件名就可以運行?9. python - 能通過CAN控制一部普通的家用轎車嗎?10. html5 - 只用CSS如何實現input框的寬度隨框里輸入的內容長短自動適應?
