首页 > 代码库 > javascript中使用var定义变量的预编译效果
javascript中使用var定义变量的预编译效果
首先说明一点:javascript语法是非常灵活的,灵活的代价就是很容易导致不规范的编码和各种意想不到的运行结果。ECMAScript 5 引入了 严格模式 (strict mode),今后我们编写javascript代码最好都使用"use strict",规范我们的javascript代码。下面的测试代码不是基于严格模式。
alert(a); var a;//已声明未赋值 alert(b);//未声明的变量
执行结果是:a打印undefined,b报错。这说明:var a;这条语句的执行在alert(a)之前。
alert(c); var c = 1; alert(c);
执行结果:先打印undefined,后打印1。实际上只是把声明提前了,但是赋值语句仍然没有改变位置
alert(a); a = 1;
执行结果:代码报错。可见没有var关键字,变量的声明不会提前,没有”预编译”的过程。
function TestClass() { //没有使用var关键字定义的是全局变量 val = 1; alert(val); //全局变量会存放在window对象中 alert(window.val); }; //调用TestClass构造函数 test = new TestClass(); //再次验证是一个全局变量 alert(val);
没有用var,其实是定义了一个全局变量,会放在window对象中。
function TestClass() { val = 1; alert(val);//1 alert(window.val);//undefined var val = 10; alert(val);//10 alert(window.val);//undefined } var test = new TestClass(); alert(val);//js报错,变量为定义
由此可见:使用var定义变量,变量声明会被提前,但是赋值不会提前.
javascript中使用var定义变量的预编译效果
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。