码迷,mamicode.com
首页 > 编程语言 > 详细

javascript变量的作用域

时间:2015-11-27 21:52:04      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:

变量作用域:

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

//声明一个全局变量
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());

 

javascript变量的作用域

标签:

原文地址:http://www.cnblogs.com/tinyphp/p/5000997.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!