美文网首页
面向对象-严格模式、作用域

面向对象-严格模式、作用域

作者: MGd | 来源:发表于2017-03-31 19:15 被阅读4次

    严格模式

    • js有两中开发模式:
      非严格模式(默认)+严格模式(“ues strict”)
    • 严格模式:会进行更严格的代码检查
    • 区别:
      以前可以的特性在严格模式下可能被禁止使用
      以前可以使用的代码方式,在严格模式下会直接报错
    • 开启严格模式:
    • 字符串命令“ues strict”
    • 位置:当前作用域的最顶端
    • 兼容性问题:
    • 严格模式不存在兼容的问题,如果当前的浏览器支持严格模式,那么扫描到命令的时候会开启严格模式检查,如果不支持则直接忽略。
    • 使用建议:写代码的时候全部开启严格模式
    • 在严格模式下的使用注意点:
    • 1.所用的变量必须使用var声明(否则会报错)
    • 2.禁止使用八进制()
    var num = 033   //数值以0开头,是以八进制的方式来处理
    直接报错
    var num = 0x33   //数值以0x开头,是以十六进制的方式来处理
    不会报错
    
    • 3.禁止使用with
    • 4.不能删除全局的变量
    在严格模式下,不能删除全局变量(直接报错)
    在默认情况下,可以删除全局变量,会静默失败(报错却不显示)
    
    • 5.不能在if语句中声明函数
    • 6.函数的形参不能出现同名的情况
    • 7.不能使用callee||caller
    • 8.不能使用eval和arguments作为标识符(变量和函数的名称)
    • 9.修正了this的指向
    function func(){
    console.log(this);
    }
    func();
    默认情况下,this指向的是window,严格模式下this指向的是undefind
    
    • 10.arguments的表现不一致
    在默认情况下,如果函数内部形参被重新设置,那么arguments也会跟着改变
    在严格模式情况下,如果函数内部形参被重新设置,那么arguments不会被改变,他们是相互独立的。
    值类型的数据作为函数的参数
    引用类行的数据作为函数的参数
    
    • 11.对象中不能出现同名的属性

    作用域

    • “ues strict”的位置:当前作用域的最顶端
      (只会对当前作用域有影响)
    • js中的作用域:
    • script:全局作用域
    • 函数内部:局部作用域
    • 作用域:
    • 概念:变量或者是函数起作用的范围。
    • js的作用域:
    • js本身没有块级作用域
    • js中只有函数可以创建作用域
    • js本身是词法作用域(with||eval)
      • 词法作用域:当代码写好之后,某个变量的作用域就已经确定了
        • 访问规则:
          1.单向性的(单向镜)内部的作用域可以访问外层的作用域空间,反过来却不行
          2.在访问变量的时候,在先前作用域中查找,如果找不到那么就在上级作用域中查找,重复这个过程
          3.在分析输出的时候,需要考虑到变量和函数声明的提升
      • 动态作用域:变量的作用域在代码运行之前是不确定的,只有在代码执行的时候才会根据上下文确定
    var demo = "测试";
    function fi(){
        var demo = "demo";
        f2();
    }
    function f2(){
        console.log(demo);
    }
    f2()   //测试
    f1()  //测试
    
    • js代码的执行
    • 编译语言
    • 脚本语言(解释性的语言)
      1.预先解析阶段
      变量和声明的提升
      2.具体执行的代码
    • js变量和函数声明的提升
    • 注意点:
      变量和变量同名,后面的变量会把前面的变量覆盖
      函数和函数同名,后面覆盖前面
      变量和函数同名,函数声明会正常的提升,而变量的声明可以认为被忽略了。
      1.在执行代码之前,会把所有的变量和函数声明进行提升
      2.在提升的时候,变量和函数生明的提升是分作用域的,只能提升到当前作用域的顶端。
      3.内层作用域中的变量声明并不会覆盖外层作用域的同名变量
    • 函数表达式的提升
    • 如果是函数表达式提升,那么在提升的时候仅仅只会把声明的部分(var fun)提升到当前作用域的顶端
    • 作用域链
    • 在JS中函数可以创建作用域,在函数内部又可以声明函数,-->。
      1.在访问变量的时候,总是先在自己的作用域中查找
      2.如果没有就向上一级查找,找到的话直接使用,没有继续查找
      3.直到最外层的全局作用域
    • 作用域数量:函数的个数加1
    • 内层的作用域可以访问外层的作用域,外层的作用域不可以访问内层的
    • 相同的作用域可以相互访问

    相关文章

      网友评论

          本文标题:面向对象-严格模式、作用域

          本文链接:https://www.haomeiwen.com/subject/csvmottx.html