zoukankan      html  css  js  c++  java
  • javascript变量的作用域

    变量作用域:局部和全局

    局部变量优先级别高于同名的全局变量

    //声明一个全局变量
    var scope="global";
    function checkscope(){
        //声明一个同名的局部变量
        var scope="local";
        //返回的是局部变量的值
        return scope;
    }
    //=>"local"
    console.log(checkscope()); 

    嵌套函数的作用域:

    //全局变量
    var scope="global scope";
    function checkscope(){
        //局部变量
        var scope="local scope";
        function nested(){
            //嵌套内的局部变量
            var scope="nested scope";
            return scope;
        }
        return nested();
    }
    //=>nested scope
    console.log(checkscope());

    正常情况下,函数外无法读取函数内局部变量

    function checkscope(){
        //局部变量
        var scope="local";
    }
    // scope is not defined
    checkscope();
    console.log(scope);

    函数内部声明变量的时候,一定要使用var命令。如果不用的话,你实际上声明了一个全局变量!

    function checkscope(){
        //相当于全局变量
        scope="global";
    }
    // =>global
    checkscope();
    console.log(scope);

    如何从外部读取局部变量呢?正常情况下确实不行,但是可以变通一下,不是说函数内部的可以获得外部的变量嘛?那我们就在函数里加一个函数返回出去

    function checkscope() {
        //局部变量
       var scope = "local";
       function getScope(){
               return scope;
       }
       return getScope;
    }
    
    var result=checkscope();
    // =>local
    console.log(result());
  • 相关阅读:
    关于页面的已终止操作
    Assembly Manifest 通俗简易手册
    C# Enumeration 使用
    打架必备!擒敌拳116动连贯动作 分解动作
    解决js中onMouseOut事件冒泡的问题
    DOM标准与IE的html元素事件模型区别
    vim编辑器
    linux常用的命令解释
    搭建本地仓库
    Linux系统虚拟机安装
  • 原文地址:https://www.cnblogs.com/tinyphp/p/5000997.html
Copyright © 2011-2022 走看看