在写js代码的时候,经常会因为这样或者那样的原因用到全局变量,如果全局变量只在一个js里使用,那就没问题,但如果变量在不同的js文件里出现,这时隐藏的问题就会开始暴露,也许你能很快修复出现的BUG,又或许全无头绪。

先看下边的js文件test1.js

var a = 1,
b = 2,
c = a + b;//此时c的值为3

html代码如下:

<html>
<head>
</head>
<body>
<script src="test1.js"></script>
<script>
alert(c);//对话框显示3
</script>
</body>
</html>

上边的test1.js文件在单独使用的时候,毫无疑问,是正确的,c的值就是我们期望的3。但是经常会遇到一个项目由多个人来合作开发,然后另一个同事给网页加载另一个test2.js,代码如下:

var a = 3,
b = 4,
c = a + b;

修改后的html代码如下:

<html>
<head>
</head>
<body>
<script src="test1.js"></script>
<script src="test2.js"></script>
<script>
alert(c);//对话框显示7
</script>
</body>
</html>

也就是说,test1.js中的变量被test2.js中同名变量给覆盖了!如果声明的变量越多,那么变量冲突就越频繁,这会让我们在新增变量的时候都提心吊胆。那么,有什么解决方案吗?答案是肯定的,下边磨途歌将给大家介绍“变量命名空间”简单的使用方法。

更改后的test1.js代码:

var _test1 = {
a : 1,
b : 2,
c : 0
};
_test1.c = _test1.a + _test1.b;//此时c的值为3

更改后的test2.js代码:

var _test2 = {
a : 3,
b : 4,
c : 0
};
_test2.c = _test2.a + _test2.b;//此时c的值为7

修改后的html代码如下:

<html>
<head>
</head>
<body>
<script src="test1.js"></script>
<script src="test2.js"></script>
<script>
alert(_test1.c);//对话框显示3
alert(_test2.c);//对话框显示7
</script>
</body>
</html>

跟磨途歌一起分析上边的代码,不难发现,test1.js与test2.js代码中声明的变量分别使用当前的文件名加一个下划线来组成,例如编写test1.js文件,那么就在文件的开头声明一个全局变量。

var _test1 = {};
//然后在需要的时候往变量里添加需要的变量
//例如下边的使用方式
_test1.x = 1;
_test1.y = 2;
_test1.z = test1.x + test1.y;

因为磨途歌不可能在同一个目录创建两个test1.js文件,这样就很巧妙的避免了同名变量的出现。还要注意一点,就是ie跟火狐或谷歌是有差异的,比如下边的代码:

var _test1 = {
a : 1,
b : 2,
c : 0,
};

最后一个“c : 0,”声明后边加不加逗号,火狐浏览器跟谷歌浏览器都能解析,但是IE浏览器就不行,IE浏览器要求最后一个变量不能有逗号的出现,所以大家以后写代码,还是得照顾一下IE浏览器的固执,改成下边这么写:

var _test1 = {
a : 1,
b : 2,
c : 0
};

如果你正好遇上在火狐浏览器跟谷歌浏览器都能正常运行的js代码,但到了IE浏览器下就不工作了的情况,可以现在就检查一下,会不会就是这个逗号让IE浏览器不高兴了?

js使用心得——避免全局变量冲突的小技巧的更多相关文章

  1. HTML5+js页面传值给Java后台的小技巧

    页面传值小技巧 平常我们在做的web项目,一般一个HTML页面上会有好几个步骤,step_num①,step_num②,step_num③,一般先显示step_num①,根据跳转条件显示step_nu ...

  2. js中关于数组处理的一些小技巧

    1 reduce方法同时实现map和filter 假设现在有一个数组,然后遍历它的每一项(map的功能)然后筛选出其中的一部分(filter的功能).如果使用map和filter的话,我们需要遍历这个 ...

  3. 微信小程序js学习心得体会

    微信小程序js学习心得体会 页面控制的bindtap和catchtap 用法,区别 <button id='123' data-userDate='100' bindtap='tabMessag ...

  4. 客户端JS性能的一些优化的小技巧

    下面是一些关于客户端JS性能的一些优化的小技巧:1.[顶]关于JS的循环,循环是一种常用的流程控制.JS提供了三种循环:for(;;). while().for(in).在这三种循环中 for(in) ...

  5. 由于js词法性质和全局变量被更改,循环绑定的click事件执行时变量和定义时 不一致的bug,各种解决方案。

    由于js词法性质和全局变量被更改,循环绑定的click事件执行时变量和定义时 不一致的bug,各种解决方案. 动态在页面上添加了5个按钮,实现的功能应该是点击对应按钮在控制台输出相应的索引.但因为应该 ...

  6. IT咨询顾问:一次吐血的项目救火 java或判断优化小技巧 asp.net core Session的测试使用心得 【.NET架构】BIM软件架构02:Web管控平台后台架构 NetCore入门篇:(十一)NetCore项目读取配置文件appsettings.json 使用LINQ生成Where的SQL语句 js_jquery_创建cookie有效期问题_时区问题

    IT咨询顾问:一次吐血的项目救火   年后的一个合作公司上线了一个子业务系统,对接公司内部的单点系统.我收到该公司的技术咨询:项目启动后没有规律的突然无法登录了,重新启动后,登录一断时间后又无法重新登 ...

  7. JS处理事件小技巧

    今天,就分享一下我自己总结的一些JS的小技巧: ①防止鼠标选中事件 <div class="mask" onselectstart="return false&qu ...

  8. [转载]Js小技巧||给input type=“password”的输入框赋默认值

    http://www.cnblogs.com/Raywang80s/archive/2012/12/06/2804459.html [转载]Js小技巧||给input type="passw ...

  9. html/css/js小技巧实例

    一些学习中碰到的小技巧 让div自动撑起来: .clearfix:after{ content: "."; clear: both; display: block; visibil ...

随机推荐

  1. servlet-api api文档获取请求参数

    1.假如有个get请求后面带有的参数如下: a=b&a2=b2&a3=b3&a4=b4. 如果想获取所有的key,value.这个时候可以根据request的getQueryS ...

  2. Okhttp 多次调用同一个方法出现错误java.net.SocketException: Socket closed

    Okhttp 多次调用同一个方法出现错误java.net.SocketException: Socket closed https://blog.csdn.net/QQiqq1314/article/ ...

  3. Go-方法-接口-异常处理-错误处理

    方法 什么是方法? 方法其实就是一个函数,在 func 这个关键字和方法名中间加入了一个特殊的接收器类型.接收器可以是结构体类型或者是非结构体类型.接收器是可以在方法的内部访问的. package m ...

  4. ubuntu服务器上配置tomcat

    前言 嗯,最近想在自己的腾讯云服务器上跑个项目玩玩,由于服务器是重装的系统,所以,只能自己手动装tomcat. 不过,tomcat是基于java的,必须又java环境tomcat才能够使用,因此首先要 ...

  5. VC调用VB写的COM

    VB. 步骤: 1.创建类库:类库的创建必须分为接口和实现类:给外面提供的是COM接口: 创建了接口和类之后还要创建"Guid",这个在"工具->创建GUID&qu ...

  6. image compression with libjpeg

    http://www.aaronmr.com/en/2010/03/test/ Working on the project I've seen in the need for compression ...

  7. 13)编写一个子类SnakeCtrl来继承基类

    1)首先是创建子类SnakeCtrl 2)     添加那个SnakeCtrl子类 3)出来了SnakeCtrl的基本样子 4)简单实现: ①改编那个SnakeCtrl.h中的内容: #pragma ...

  8. day59-mysql-存储过程、函数、事务、锁、备份

    存储过程.函数不是重要的内容. 三. 存储过程:类似于函数(方法),简单的说存储过程是为了完成某个数据库中的特定功能而编写的语句集合, 该语句集包括SQL语句(对数据的增删改查).条件语句和循环语句等 ...

  9. 【图论算法】Dijstra&BFS

    选择V-S中的点加入S时用了贪心思想,即求d[]中legth最小且未被标记(未加入加入S)的点. 一点都没优化的实现: import java.lang.reflect.Array; /** * Cr ...

  10. 微信小程序使用第三方FontIcon库的部分字体图标

    一.提取部分图标重新制作TTF字库 我没有使用网上大多数文章写的淘宝提供的fonticon,而只使用了Ionicons的几个图标,所以打开Ionicons的官网点击右上角的Designer pack下 ...