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技巧--转义符"\"的妙用
Jan 09 Javascript
Document对象内容集合(比较全)
Sep 06 Javascript
JQuery 返回布尔值Is()条件判断方法代码
May 14 Javascript
关于jQuery新的事件绑定机制on()的使用技巧
Apr 26 Javascript
输入自动提示搜索提示功能的javascript:sugggestion.js
Sep 02 Javascript
jQuery回调函数的定义及用法实例
Dec 23 Javascript
Angularjs上传图片实例详解
Aug 06 Javascript
react-router 路由切换动画的实现示例
Dec 03 Javascript
微信小程序时间选择插件使用详解
Dec 28 Javascript
微信小程序实现九宫格抽奖
Apr 15 Javascript
javascript头像上传代码实例
Sep 28 Javascript
Nest.js参数校验和自定义返回数据格式详解
Mar 29 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
信用卡效验程序
2006/10/09 PHP
PHP 一个页面执行时间类代码
2010/03/05 PHP
PHP处理Oracle的CLOB实例
2014/11/03 PHP
CI框架验证码CAPTCHA辅助函数用法实例
2014/11/05 PHP
php each 返回数组中当前的键值对并将数组指针向前移动一步实例
2016/11/22 PHP
php实现水印文字和缩略图的方法示例
2016/12/29 PHP
laravel 解决ajax异步提交数据,并还回填充表格的问题
2019/10/15 PHP
利用jquery包将字符串生成二维码图片
2013/09/12 Javascript
getJSON调用后台json数据时函数被调用两次的原因猜想
2013/09/29 Javascript
javaScript中的this示例学习详解及工作原理
2014/01/13 Javascript
jQuery插件windowScroll实现单屏滚动特效
2015/07/14 Javascript
基于iscroll.js实现下拉刷新和上拉加载效果
2016/11/28 Javascript
vue上传图片组件编写代码
2017/07/26 Javascript
JavaScript全屏和退出全屏事件总结(附代码)
2017/08/17 Javascript
基于node.js的fs核心模块读写文件操作(实例讲解)
2017/09/10 Javascript
纯JavaScript实现实时反馈系统时间
2017/10/26 Javascript
js实现动态改变radio状态的方法
2018/02/28 Javascript
详解Koa中更方便简单发送响应的方式
2018/07/20 Javascript
vue定义全局变量和全局方法的方法示例
2018/08/01 Javascript
解决vue项目运行提示Warnings while compiling.警告的问题
2020/09/18 Javascript
vue编写简单的购物车功能
2021/01/08 Vue.js
[05:08]2014DOTA2国际邀请赛 Hao专访复仇的胜利很爽
2014/07/15 DOTA
[04:10]2016国际邀请赛中国区预选赛第二日TOP10精彩集锦
2016/06/28 DOTA
介绍Python的Django框架中的QuerySets
2015/04/20 Python
Django REST framework 单元测试实例解析
2019/11/07 Python
基于h5py的使用及数据封装代码
2019/12/26 Python
pytorch:torch.mm()和torch.matmul()的使用
2019/12/27 Python
Python通过Tesseract库实现文字识别
2020/03/05 Python
python文件及目录操作代码汇总
2020/07/08 Python
Mountain Hardwear官网:攀岩服装和户外装备
2019/09/26 全球购物
Java基础知识面试题
2014/03/25 面试题
计划生育证明格式范本
2014/09/12 职场文书
2015年全国“爱牙日”宣传活动总结
2015/03/23 职场文书
催款函范本大全
2015/06/24 职场文书
分析SQL窗口函数之排名窗口函数
2022/04/21 Oracle
uniapp 微信小程序 自定义tabBar 导航
2022/04/22 Javascript