您的位置:首页技术文章
文章详情页

javascript - js中如何实现静态变量

浏览:60日期: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
相关文章: