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 相关文章推荐
JavaScript写的一个DIV 弹出网页对话框
Aug 14 Javascript
Extjs4 消息框去掉关闭按钮(类似Ext.Msg.alert)
Apr 02 Javascript
IE下写xml文件的两种方式(fso/saveAs)
Aug 05 Javascript
JS实现仿百度输入框自动匹配功能的示例代码
Feb 19 Javascript
详解Javacript和AngularJS中的Promises
Feb 09 Javascript
一些实用性较高的js方法
Apr 19 Javascript
深入浅析JS Function()构造函数
Aug 22 Javascript
Angularjs 实现动态添加控件功能
May 25 Javascript
解决Linux无法正常安装与卸载Node.js的方法
Jan 19 Javascript
JS实现的合并多个数组去重算法示例
Apr 11 Javascript
基于layui的table插件进行复选框联动功能的实现方法
Sep 19 Javascript
vue自定义switch开关组件,实现样式可自行更改
Nov 01 Javascript
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 has encountered an Access Violation 错误的解决方法
2010/01/17 PHP
fleaphp crud操作之find函数的使用方法
2011/04/23 PHP
PHP Laravel中的Trait使用方法
2019/01/20 PHP
原生JS实现加入收藏夹的代码
2013/10/24 Javascript
使用 Node.js 做 Function Test实现方法
2013/10/25 Javascript
js中opener与parent的区别详细解析
2014/01/14 Javascript
jQuery中:has选择器用法实例
2014/12/30 Javascript
jQuery随手笔记之常用的jQuery操作DOM事件
2015/11/29 Javascript
Node.js静态文件服务器改进版
2016/01/10 Javascript
你所未知的3种Node.js代码优化方式
2016/02/25 Javascript
vue 运用mock数据的示例代码
2017/11/07 Javascript
angular2路由之routerLinkActive指令【推荐】
2018/05/30 Javascript
前端防止用户重复提交js实现代码示例
2018/09/07 Javascript
javascript中函数的写法实例代码详解
2018/10/28 Javascript
[40:10]2015国际邀请赛全明星表演赛
2015/08/07 DOTA
Python新手实现2048小游戏
2015/03/31 Python
六个窍门助你提高Python运行效率
2015/06/09 Python
python操作mysql数据库
2017/03/05 Python
浅谈python 线程池threadpool之实现
2017/11/17 Python
python批量设置多个Excel文件页眉页脚的脚本
2018/03/14 Python
详解Python读取yaml文件多层菜单
2019/03/23 Python
selenium处理元素定位点击无效问题
2019/06/12 Python
Python OpenCV实现鼠标画框效果
2020/08/19 Python
Python字节单位转换实例
2019/12/05 Python
python 实现图片上传接口开发 并生成可以访问的图片url
2019/12/18 Python
对tensorflow中cifar-10文档的Read操作详解
2020/02/10 Python
Opencv图像处理:如何判断图片里某个颜色值占的比例
2020/06/03 Python
德国旅游网站:weg.de
2018/06/03 全球购物
英国领先的互联网葡萄酒礼品商:Vintage Wine & Port
2019/05/24 全球购物
大学生自我评价怎样写好
2013/10/23 职场文书
大学自我鉴定范文
2013/12/26 职场文书
实习协议书范本
2014/04/22 职场文书
超市七夕促销活动方案
2014/08/28 职场文书
教师党员先进性教育自我剖析材料思想汇报
2014/09/24 职场文书
2014年为民办实事工作总结
2014/12/20 职场文书
致创业的您:这类人不适合餐饮创业
2019/08/19 职场文书