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 不只是脚本
May 30 Javascript
jQuery的强大选择器小结
Dec 27 Javascript
JQuery 构建客户/服务分离的链接模型中Table中的排序分析
Jan 22 Javascript
js/jquery解析json和数组格式的方法详解
Jan 09 Javascript
javascript中的正则表达式使用指南
Mar 01 Javascript
jQuery实现的动态伸缩导航菜单实例
May 07 Javascript
javascript中的作用域和闭包详解
Jan 13 Javascript
纯JS打造网页中checkbox和radio的美化效果
Oct 13 Javascript
js图片轮播手动切换特效
Jan 12 Javascript
ES6中Array.copyWithin()函数的用法实例详解
Sep 16 Javascript
解决vue 格式化银行卡(信用卡)每4位一个符号隔断的问题
Sep 14 Javascript
Vue 幸运大转盘实现思路详解
May 06 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入门教程 精简版
2009/12/13 PHP
php查找任何页面上的所有链接的方法
2013/12/03 PHP
php中字符串和正则表达式详解
2014/10/23 PHP
JS 拼图游戏 面向对象,注释完整。
2009/06/18 Javascript
js调用AJAX时Get和post的乱码解决方法
2013/06/04 Javascript
JQuery获取表格数据示例代码
2014/05/26 Javascript
javascript的tab切换原理与效果实现方法
2015/01/10 Javascript
ActiveX控件的使用-js实现打印超市小票功能代码详解
2017/11/22 Javascript
微信小程序实现指定显示行数多余文字去掉用省略号代替
2018/07/25 Javascript
微信小程序自定义音乐进度条的实例代码
2018/08/28 Javascript
Vue 组件参数校验与非props特性的方法
2019/02/12 Javascript
微信小程序页面间传递数组对象方法解析
2019/11/06 Javascript
python中cPickle用法例子分享
2014/01/03 Python
跟老齐学Python之使用Python查询更新数据库
2014/11/25 Python
python搭建虚拟环境的步骤详解
2016/09/27 Python
浅析Python中yield关键词的作用与用法
2016/11/29 Python
Python数据分析之双色球统计两个红和蓝球哪组合比例高的方法
2018/02/03 Python
python中的文件打开与关闭操作命令介绍
2018/04/26 Python
python网络编程 使用UDP、TCP协议收发信息详解
2019/08/29 Python
python redis存入字典序列化存储教程
2020/07/16 Python
如何真正的了解python装饰器
2020/08/14 Python
Python爬取酷狗MP3音频的步骤
2021/02/26 Python
html5本地存储 localStorage操作使用详解
2016/09/20 HTML / CSS
Vinatis德国:法国领先的葡萄酒邮购公司
2020/09/07 全球购物
深圳-东方伟业笔试部分
2015/02/11 面试题
UNIX特点都有哪些
2016/04/05 面试题
教师自我鉴定
2013/12/13 职场文书
小学母亲节活动方案
2014/03/14 职场文书
干部个人考察材料
2014/12/24 职场文书
自主招生自荐信怎么写
2015/03/24 职场文书
辩论赛新闻稿
2015/07/17 职场文书
诚信教育主题班会
2015/08/13 职场文书
2016年感恩教师节活动总结
2016/04/01 职场文书
vue中三级导航的菜单权限控制
2021/03/31 Vue.js
在Django中使用MQTT的方法
2021/05/10 Python
JavaScript中isPrototypeOf函数
2021/11/07 Javascript