javascript - js中如何实现静态变量
天蓬老师
天蓬老师 2017-06-26 10:58:14
[JavaScript讨论组]
<button type="button" onclick="func();">按钮</button>

var i = 0;
func(){
    i += 1;
    console.log(i)
}

需求:点击按钮变量自增1。求最好的实现方法。
补充一下,实现方法有很多。

  1. 直接保存到全局变量里——污染了全局命名空间

  2. 使用一个全局数组保存当前app的全局变量——不符合当前架构

  3. 闭包——似乎不适应当前场景(使用onclick触发函数)

  4. 停靠到html元素中——还是很low

  5. 使用一个大的匿名函数延长变量的生命周期——不符合当前架构

天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回复(5)
某草草

谁说闭包不适用?

var func = (function(){
var i = 0;
return function(){
    i++;
    console.log(i);
}

}());

或者你可以这样:

var func = function(){
    func.i++;
    console.log(func.i);
};
func.i = 0;
PHP中文网

保存在dom节点属性中

<button data-click-number="0" type="button" id="incBtn" >按钮</button>
$("#incBtn").on('click',function(){
 var preClickNumber=$(this).attr('data-click-number') ?: 1;
 $(this).attr('data-click-number',preClickNumber++);
});
过去多啦不再A梦

js没有静态变量。 只有局部变量与全局变量。

<button type="button" onclick="++i">按钮</button>

var i = 0;
大家讲道理

难道不是用let

黄舟

闭包大发好,建议题主去看看javascript的函数式的一些书籍,这也是JavaScript的一大特色

let click = (() => {
    var i = 0;
    return function() {
      i += 1;
      console.log(i)
    }
})()
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号