zoukankan      html  css  js  c++  java
  • JavaScript中的关键字'var'还是有文章的(转)

      都不记得是什么时候看的JScript的语法教程了,里面说在声明变量时忽略var关键字是完全合法的。当时也因为觉得JavaScript是loosely-typed的语言,所以var可能真的就是个摆设。但是事实常常又证明想当然的结果是不可靠的

        看看下面这几个例子的结果就知道问题了:

        No.1

    <script language="javascript">
    var var00 = 0;
    document.write(var00 
    + '<br>');

    var var01 = 1;
    function foo()
    {
        document.write(var01); 
        
    var var01 = 1;
    }

    foo();
    </script>

     
        No.2

    <script language="javascript">
    var00 
    = 0;
    document.write(var00 
    + '<br>');

    var01 
    = 1;
    function foo()
    {
        document.write(var01); 
        var01 
    = 1;
    }

    foo();
    </script>

     
        No.3

    <script language="javascript">
    var00 
    = 0;
    document.write(var00 
    + '<br>');

    var01 
    = 1;
    function foo()
    {
        document.write(var01); 
        
    var var01 = 1;
    }

    foo();
    </script>

     
        这三个例子的执行结果分别是:

    #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。


       By the way, 重看JScript教程时,它说变量只能是[a-zA-Z_]+[a-zA-Z0-9_]*格式,可是'$'却也可以作为变量名字符,而且还可以用在开头,比如:$1234,更甚至于:$$$ 也是合法的变量名,faint。

  • 相关阅读:
    Oracle存储过程例子:运用了正则表达式、数组等
    Oracle正则表达式中注意的问题
    先取主键最大值再取extracted_time,替换Max(extracted_time)会有更高的效率
    临时表的使用及minus运算
    设置自动管理空间
    字段以Byte(字节)或char(字符)存储的设置
    javascript控制页面控件隐藏显示的两种方法
    Javascript遍历页面控件
    精妙的SQL和SQL SERVER 与ACCESS、EXCEL的数据导入导出转换
    事半功倍系列之javascript (转载)
  • 原文地址:https://www.cnblogs.com/aming/p/1258009.html
Copyright © 2011-2022 走看看