小5聊jQuery基础开发之挖坑自己跳,变量未设置var,局部变量变成了全局变量

Posted 小5聊

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了小5聊jQuery基础开发之挖坑自己跳,变量未设置var,局部变量变成了全局变量相关的知识,希望对你有一定的参考价值。

按原理来说,$(function(){  A }),$(function(){  B }),内容A和B之间的变量应该不会相互影响

1、错误写法

  • 效果

 按逻辑应该是弹出1才对

  •  代码

<script type="text/javascript">
    $(function () {

        gData = {
            data: null,
            xgwTest: function () {

                alert("1");
            }
        }

        setTimeout(function () {

            gData.xgwTest();
        }, 2 * 1000);
    });
</script>

<script type="text/javascript">

    $(function () {

        gData = {
            data: null,
            xgwTest: function () {

                alert("2");
            }
        }
    });
</script>

2、正确写法

  • 效果

 

  • 代码

<script type="text/javascript">
    $(function () {

        var gData = {
            data: null,
            xgwTest: function () {

                alert("1");
            }
        }

        setTimeout(function () {

            gData.xgwTest();
        }, 2 * 1000);
    });
</script>

<script type="text/javascript">

    $(function () {

        var gData = {
            data: null,
            xgwTest: function () {

                alert("2");
            }
        }
    });
</script>

3、总结

这说明,不管你定义的变量是在类似闭包函数也好,只要变量前没有加关键词,就默认是全局变量,导致前面定义的功能会被后面相同功能覆盖。

有时候往往被自己不细心不理解到位坑哭了

以上是关于小5聊jQuery基础开发之挖坑自己跳,变量未设置var,局部变量变成了全局变量的主要内容,如果未能解决你的问题,请参考以下文章

小5聊jQuery使用on绑定未来元素同时off仍然出现被绑定多次click点击事件分析和原因,自己挖坑系列

小5聊jquery基础之offset和position的topleft值

自己挖坑,自己跳

小5聊jQuery基础之触发a标签的click事件无效的解决方法

小5聊.net core 2.1基础开发之视图方法可访问但页面显示500报错

小5聊C#基础知识之Decimal变量类型