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 相关文章推荐
js 发个判断字符串是否为符合标准的函数
Apr 27 Javascript
js数据验证集合、js email验证、js url验证、js长度验证、js数字验证等简单封装
May 15 Javascript
改进版通过Json对象实现深复制的方法
Oct 24 Javascript
js调用AJAX时Get和post的乱码解决方法
Jun 04 Javascript
jquery实现背景墙聚光灯效果示例分享
Mar 02 Javascript
bootstrap data与jquery .data
Jul 07 Javascript
总结JavaScript的正则与其他语言的不同之处
Aug 25 Javascript
jquery拼接ajax 的json和字符串拼接的方法
Mar 11 Javascript
JavaScript条件判断_动力节点Java学院整理
Jun 26 Javascript
详谈ES6中的迭代器(Iterator)和生成器(Generator)
Jul 31 Javascript
jquery实现动态添加附件功能
Oct 23 jQuery
vue scroll滚动判断的实现(是否滚动到底部、滚动方向、滚动节流、获取滚动区域dom元素)
Jun 11 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中的日期及时间
2006/11/23 PHP
php部分常见问题总结
2008/03/27 PHP
Trying to clone an uncloneable object of class Imagic的解决方法
2012/01/11 PHP
在Mac OS上搭建Nginx+PHP+MySQL开发环境的教程
2015/12/21 PHP
TP5(thinkPHP5)框架基于ajax与后台数据交互操作简单示例
2018/09/03 PHP
PHP常用函数之格式化时间操作示例
2019/10/21 PHP
javascript 火狐(firefox)不显示本地图片问题解决
2008/07/05 Javascript
谷歌浏览器 insertCell与appendChild的区别
2009/02/12 Javascript
Javascript 的addEventListener()及attachEvent()区别分析
2009/05/21 Javascript
表单JS弹出填写提示效果代码
2011/04/16 Javascript
AngularJS模块管理问题的非常规处理方法
2015/04/29 Javascript
jQuery插件实现文字无缝向上滚动效果代码
2016/02/25 Javascript
javascript实现获取图片大小及图片等比缩放的方法
2016/11/24 Javascript
AngularJS之自定义服务详解(factory、service、provider)
2017/04/14 Javascript
Vue编写多地区选择组件
2017/08/21 Javascript
详解elementui之el-image-viewer(图片查看器)
2019/08/30 Javascript
浅谈vue异步数据影响页面渲染
2019/10/29 Javascript
微信小程序select下拉框实现源码
2019/11/08 Javascript
vue中 v-for循环的用法详解
2020/02/19 Javascript
python学习手册中的python多态示例代码
2014/01/21 Python
Python bsddb模块操作Berkeley DB数据库介绍
2015/04/08 Python
Python中index()和seek()的用法(详解)
2017/04/27 Python
python求绝对值的三种方法小结
2019/12/04 Python
Django values()和value_list()的使用
2020/03/31 Python
德国家具折扣店:POCO
2020/02/28 全球购物
Puccini乌克兰:购买行李箱、女士手袋网上商店
2020/08/06 全球购物
交通安全教育制度
2014/02/02 职场文书
农业局学习党的群众路线教育实践活动心得体会
2014/03/07 职场文书
老公爱的承诺书
2014/03/31 职场文书
拓展策划方案
2014/06/03 职场文书
甘南现象心得体会
2014/09/11 职场文书
单位一把手群众路线四风问题整改措施
2014/09/25 职场文书
股份转让协议书范本
2015/01/27 职场文书
在pycharm中无法import所安装的库解决方案
2021/05/31 Python
react使用antd的上传组件实现文件表单一起提交功能(完整代码)
2021/06/29 Javascript
Python 数据可视化之Bokeh详解
2021/11/02 Python