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与下拉列表处理问题解决
Feb 13 Javascript
javascript的动态加载、缓存、更新以及复用(一)
Jun 09 Javascript
Jquery使用css方法改变样式实例
May 18 Javascript
浅谈javascript原型链与继承
Jul 13 Javascript
jQuery实现Flash效果上下翻动的中英文导航菜单代码
Sep 22 Javascript
php基于redis处理session的方法
Mar 14 Javascript
简单解析JavaScript中的__proto__属性
May 10 Javascript
简单谈谈ES6的六个小特性
Nov 18 Javascript
JS封装通过className获取元素的函数示例
Dec 20 Javascript
js jquery 获取某一元素到浏览器顶端的距离实现方法
Sep 05 jQuery
vue 子组件watch监听不到prop的解决
Aug 09 Javascript
vue3 自定义图片放大器效果的示例代码
Jul 23 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
BBS(php & mysql)完整版(六)
2006/10/09 PHP
禁止直接访问php文件代码分享
2020/05/05 PHP
使用jQuery向asp.net Mvc传递复杂json数据-ModelBinder篇
2010/05/07 Javascript
JS实现的Select三级下拉菜单代码
2015/08/20 Javascript
JS实现选项卡实例详解
2015/11/17 Javascript
轻松搞定jQuery.noConflict()
2016/02/15 Javascript
vue实现todolist单页面应用
2017/04/11 Javascript
vue2中使用sass并配置全局的sass样式变量的方法
2018/09/04 Javascript
微信小程序登陆注册功能的实现代码
2019/12/10 Javascript
Javascript类型判断相关例题及解析
2020/08/26 Javascript
ant design vue导航菜单与路由配置操作
2020/10/28 Javascript
python中合并两个文本文件并按照姓名首字母排序的例子
2014/04/25 Python
python BeautifulSoup设置页面编码的方法
2015/04/03 Python
python 字典(dict)按键和值排序
2016/06/28 Python
Python入门_浅谈for循环、while循环
2017/05/16 Python
Python二叉树的定义及常用遍历算法分析
2017/11/24 Python
Python的地形三维可视化Matplotlib和gdal使用实例
2017/12/09 Python
python 列表,数组,矩阵两两转换tolist()的实例
2018/04/04 Python
Python global全局变量函数详解
2018/09/18 Python
利用python计算时间差(返回天数)
2019/09/07 Python
Python使用Tkinter实现转盘抽奖器的步骤详解
2020/01/06 Python
pytorch masked_fill报错的解决
2020/02/18 Python
详解css3 mask遮罩实现一些特效
2018/10/24 HTML / CSS
深入解析HTML5中的Blob对象的使用
2015/09/08 HTML / CSS
世界首屈一指的在线男士内衣权威:HisRoom
2017/08/05 全球购物
德国购买健身器材:AsVIVA
2017/08/09 全球购物
意大利灯具购物网站:Lampade.it
2018/10/18 全球购物
如何通过jdbc调用存储过程
2012/04/19 面试题
优秀交警事迹材料
2014/01/26 职场文书
法定代表人授权委托书
2014/04/04 职场文书
教师工作失职检讨书
2014/09/18 职场文书
销售人员工作自我评价
2014/09/21 职场文书
2015年生产部工作总结范文
2015/05/25 职场文书
2016年秋季运动会加油稿
2015/12/21 职场文书
大学生入党自我鉴定范文
2019/06/21 职场文书
CentOS8.4安装Redis6.2.6的详细过程
2021/11/20 Redis