JS中变量声明var , this , 和let 的区别

var xx;

function test(){
        var aa; //声明一
        let bb;//声明二
        this.cc;//声明三

        //声明一局部代码块
        {
            let dd;//声明四     
        }   
}

那么,这三种方式有什么区别呢?

区别在于作用域不同。

let
let 声明的变量作用域为某个代码块。而代码块的长度可大可小。
也就是说,当按声明二的方式声明一个变量时,该变量的作用范围于为整个function语句。
当按声明四方式声明一个变量时,该变量的作用范围为局部的代码块。

var
如果在函数内部,加var就是局部变量,不加是全局变量。
在函数外面,也就是说在window区域加不加var是一样的,该var变量的作用域为整个js文件周期(全局作用域)。

this
this多用于函数内部,它永远指向调用他的那个对象
简单地说,用this声明的变量作用域也是全局的。
如果实例化test函数 var p=new test() 那么用p能访问test函数内的哪些变量呢?
答案是只有cc 。实际上this声明的变量是作用于上下文的。

你可能感兴趣的:(JS中变量声明var , this , 和let 的区别)