• ES6深入浅出-1 新版变量声明:let 和 const-2.视频 let和const








    以前的var方式声明不好用

    a=1会声明一个全局变量,

    输出了1 说明a=1确实声明了一个全局变量。

    但是你把放在其他的地方,就不是声明全局变量了。

    如果外面有个全局变量a 那么函数里面就是给a赋值

    调用fn方法,输出的还是1



    有两层函数的时候,直接使用的是局部变量a,也就是fn函数里面的a

    如果当前没有a就声明一个全局变量a。如果有a就利用这个a。下面当前就是有a的

    这样用的就是最外面的var a

    如果外面也没有,这时候才会去声明一个全局变量

    所以a=1会声明一个全局变量是错的,只有在没有a这个变量的情况下才会隐式的去声明一个全局变量

    所以a=1就是含义不明

    不建议使用

    这样打印出来一个a是对的



    没有声明的情况下输出a页面会报错。没有a任何的定义就去使用它




    没有报错



    不执行的代码影响了,执行的代码
    var a会自动提升到上面去,虽然它不会执行,它会给代码一些不符合逻辑的地方,var a 会乱提升

    第二个问题

    不使用全局变量,全局变量会经常有问题,比如声明了一个全局变量,别人用了我不知道。
    用一个函数包起来。  这样var a就不是一个局部变量。

    函数给他一个名字,不管叫啥名,都是全局变量。 当前x是全局变量,frank是全局变量



    把var a放在函数里面 那么a就不是一个局部变量。

    把a包含在函数x里面。那么函数x就是一个全部变量了。 

    匿名函数直接调用,在函数的最后面加个括号。但是语法错误。

    避免这个语法错误。那么总的都包含在一个括号里面

    声明一个函数,然后马上调用它,就是只是为了这个函数没有名字而已。然后包含在括号里面,是为了不让它报语法错误。搞这么多事情就是为了不暴露全局变量

    let的特点,不会往外跑,只要看到了花括号就不会再网上升了。let就是你写在哪就是哪 不会乱跑。

    如果这时候在打印a  就会报错,提示未定义。

    把a隐藏起来不作为全局变量,在Es6之前 ,js必须使用一个立即执行函数的变态方案,新人完全看不懂
    let就是为了方便的使用局部变量,而不需要引用一个函数。

    let的作用域只管到花括号



    用var 就不会报错。

    let的第二个特点 也是可以嵌套的

    这个语法叫做块,把一堆代码扩起来。





    在一个新的块里面,还没声明a 就用a

    既不会用外面的a 也不会用里面的a。直接就报错了。这是一个很好的习惯,这样就不会出现一些奇异的代码


    let的第二个特点,如果你在一个block(块)里面。没有用let生命变量就是用这个变量。直接就会报错。 
    这个特点叫做Temp Dead Zone 临时死区

    下面选中的这部分就是临时死区,在这里面,a是不能使用的,一旦使用就报语法错误。

    换句话说就是不生命就调用, 就会直接报错

    const

    a的作用域只在选中那个括号里面。




    const只有一次赋值机会,后面再赋值就报错

    再次let a 也会报错,一个变量不能声明两次,这里直接报错。

    js终于知道在写代码的时候 就告诉你 这里有错。


    const的情况。const是常量的意思。只能赋值一次

    不能只能赋值一次,不能再次赋值

    总结


    定义const a不赋值,没运行直接就报错。所以定义const必须在定义它的时候就赋值






     

  • 相关阅读:
    C语言第三次博客作业---单层循环结构
    C语言第二次博客作业---分支结构
    C语言第一次博客作业
    第0次作业
    第09组 Beta冲刺(1/5)
    第09组 Alpha事后诸葛亮
    第09组 Alpha冲刺(6/6)
    第09组 Alpha冲刺(5/6)
    第09组 Alpha冲刺(4/6)
    第09组 Alpha冲刺(3/6)
  • 原文地址:https://www.cnblogs.com/wangjunwei/p/11546457.html
Copyright © 2020-2023  润新知