JavaScript中的关键字"VAR"使用详解 分享


Posted in Javascript onJuly 31, 2013

看看下面这几个例子的结果就知道问题了:
这三个例子的执行结果分别是:

Results#region Results
No.1
0
undefined
No.2
0
1
No.3
0
undefined
#endregion

原来JavaScript的变量也是有作用域的,只是它非常的笼统,就分为全局变量和函数变量。在第二个例子中得到0和1,是因为所有的变量都是全局变量,而且那个语句块一共就定义了两个变量。而第一个第三的函数外全局变量,确实说明var关键字有没有都没有关系。而函数内的var关键字就很关键了,它说明第二个var01是函数内的变量,所以在初始化var01前输出自然就是'undefined'了。
那么函数里面是不是就屏蔽掉了全局的var01了呢?我们知道在C/C++可以使用::去访问全局变量,那么JavaScript可不可以呢?这里其实我们只要明白了全局变量到底是什么东西,就好弄了。原来全局变量都是动态添加到Window对象的实例window上的属性而以,所以我们只要在函数内用:document.write(window.var01);就可以取到其值1了。同时在这个上下文中,function内的this也是指向的window实例,我们也可以把引用写成:this.var01。
顺便说一下,重看JScript教程时,它说变量只能是[a-zA-Z_]+[a-zA-Z0-9_]*格式,可是'$'却也可以作为变量名字符,而且还可以用在开头,比如:$1234,更甚至于:$$$ 也是合法的变量名,faint。
我想知道是不是.在调用一个函数时,程序执行顺序会先检查函数内部变量中,有没有关键字var. 然后中再根据检查结果给不同的变量付予不同的作用域和变量值.因为我看到在这三个函数中,var01变量都是在输出语句之后.
function get_global_var(___name) 
{ 
return eval(___name); 
} 
function set_global_var(___name,___value) 
{ 
eval(___name+"=___value"); 
} 
var aa=11; 
Test(); 
WScript.Echo(aa);//22 
function Test() 
{ 
var aa=33; 
WScript.Echo(get_global_var("aa"));//11 
set_global_var("aa",22); 
WScript.Echo(get_global_var("aa"));//22 
WScript.Echo(aa);//33 
}

在上面的例子中this从来就没有指过Test,而一直都是WScript的实例。
如果我们写一个语句:var test = new Test(); 这时Test里的this就是指的Test的一个实例了,这个实例中如果要使用Global的变量,Lostinet给出的是一个方法。
不过最简单还是把global传入对象,这样定义Test:
function Test(global) 
{ 
// ... 
}

然后这样创建实例:var test = new Test(this); 就可以在Test实例中使用global的对象和属性了。
是不是这样,在new的实例中,this就指实例,否则都指WScript?如果这样的话,换了脚本引擎,是不是情况又会不同?这个是标准吗?
new constructor[(arguments)];
new 运算符执行下面的任务:
·创建一个没有成员的对象。
·为那个对象调用构造函数,传递一个指针给新创建的对象作为 this 指针。
·然后构造函数根据传递给它的参数初始化该对象。
要注意的是即使当前作用域内没有调用new,但可能在其父作用域里是调用了new的,所以“在new的实例中,this就指实例,否则都指WScript?”,前半句对,而后半句不一定。
Javascript 相关文章推荐
合并table相同单元格的jquery插件分享(很精简)
Jun 20 Javascript
Js实现无刷新删除内容
Apr 29 Javascript
全面了解js中的script标签
Jul 04 Javascript
AngularJS HTML DOM详解及示例代码
Aug 17 Javascript
js获取浏览器的各种属性
Apr 27 Javascript
vue+iview写个弹框的示例代码
Dec 05 Javascript
redux中间件之redux-thunk的具体使用
Apr 17 Javascript
详解如何使用nvm管理Node.js多版本
May 06 Javascript
no-vnc和node.js实现web远程桌面的完整步骤
Aug 11 Javascript
Element Steps步骤条的使用方法
Jul 26 Javascript
vue 保留两位小数 不能直接用toFixed(2) 的解决
Aug 07 Javascript
如何使用RoughViz可视化Vue.js中的草绘图表
Jan 30 Vue.js
JavaScript 和 Java 的区别浅析
Jul 31 #Javascript
javascript检查表单数据是否改变的方法
Jul 30 #Javascript
JS 对输入框进行限制(常用的都有)
Jul 30 #Javascript
JS无限极树形菜单,json格式、数组格式通用示例
Jul 30 #Javascript
js中widow.open()方法使用详解
Jul 30 #Javascript
Extjs NumberField后面加单位实现思路
Jul 30 #Javascript
Js中获取frames中的元素示例代码
Jul 30 #Javascript
You might like
简单的php文件上传(实例)
2013/10/27 PHP
JS BASE64编码 window.atob(), window.btoa()
2021/03/09 Javascript
分享几个超级震憾的图片特效
2012/01/08 Javascript
利用js实现在浏览器状态栏显示访问者在本页停留的时间
2013/12/29 Javascript
JavaScript数组常用操作技巧汇总
2014/11/17 Javascript
浅谈JavaScript异步编程
2017/01/20 Javascript
jQuery插件zTree实现单独选中根节点中第一个节点示例
2017/03/08 Javascript
微信小程序 选项卡的简单实例
2017/05/24 Javascript
angularJS利用ng-repeat遍历二维数组的实例代码
2017/06/03 Javascript
解决vuecli3.0热更新失效的问题
2018/09/19 Javascript
JS函数进阶之prototy用法实例分析
2020/01/15 Javascript
webpack的 rquire.context用法实现工程自动化的方法
2020/02/07 Javascript
Node.js API详解之 net模块实例分析
2020/05/18 Javascript
[02:45]2016年中国刀塔全程回顾,完美“圣”典即将上演
2016/12/15 DOTA
使用Python的判断语句模拟三目运算
2015/04/24 Python
利用Python如何生成hash值示例详解
2017/12/20 Python
微信跳一跳自动运行python脚本
2018/01/08 Python
python数据批量写入ScrolledText的优化方法
2018/10/11 Python
python实现windows壁纸定期更换功能
2019/01/21 Python
浅谈python的输入输出,注释,基本数据类型
2019/04/02 Python
Python面向对象程序设计类的封装与继承用法示例
2019/04/12 Python
Python为何不能用可变对象作为默认参数的值
2019/07/01 Python
python opencv对图像进行旋转且不裁剪图片的实现方法
2019/07/09 Python
python cv2.resize函数high和width注意事项说明
2020/07/05 Python
python 获取计算机的网卡信息
2021/02/18 Python
CSS3制作hover下划线动画
2017/03/27 HTML / CSS
JBL英国官网:JBL UK
2018/07/04 全球购物
以下为Windows NT 下的32 位C++程序,请计算sizeof 的值
2016/12/07 面试题
八一建军节营销活动方案
2014/08/31 职场文书
房产协议书范本2014
2014/09/30 职场文书
离职感谢信怎么写
2015/01/22 职场文书
企业廉洁教育心得体会
2016/01/20 职场文书
实用求职信模板范文
2019/05/13 职场文书
船舶调度指挥系统——助力智慧海事
2022/02/18 无线电
《雀魂PONG☆》4月1日播出 PV角色设定情报
2022/03/20 日漫
Ruby GDBM操作简介及数据存储原理
2022/04/19 Ruby