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. java - 创建maven项目失败了 求解决方法2. 一个走错路的23岁傻小子的提问3. python - 如何使用pykafka consumer进行数据处理并保存?4. node.js - 函数getByName()中如何使得co执行完后才return5. javascript - SuperSlide.js火狐不兼容怎么回事呢6. mysql主从 - 请教下mysql 主动-被动模式的双主配置 和 主从配置在应用上有什么区别?7. python - django 里自定义的 login 方法,如何使用 login_required()8. 主从备份 - 跪求mysql 高可用主从方案9. 运行python程序时出现“应用程序发生异常”的内存错误?10. 一个mysql联表查询的问题
