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

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

作者: 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
  • 内层的作用域可以访问外层的作用域,外层的作用域不可以访问内层的
  • 相同的作用域可以相互访问

相关文章

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

    严格模式 js有两中开发模式:非严格模式(默认)+严格模式(“ues strict”) 严格模式:会进行更严格的代...

  • JavaScript中的this指向问题

    1、在全局作用域下, this指向的是window对象 2、在普通函数作用域下 在非严格模式下,this的指向依旧...

  • JS随手笔记

    传值与传地址 严格模式 **use strict ** 只对当前作用域及子作用域有效严格模式下使用的变量必须定义 ...

  • Javascript高级话题

    面向对象、作用域、闭包、设计模式等。 1. 常见的JS类定义方式 构造函数原型 对象创建 原型法是通用老方法,对象...

  • 2018-06-27

    JavaScript(面向对象+原型理解+继承+作用域链和闭包+this使用总结) 一、面向对象 1、什么是面向对...

  • 面向对象(五)--四种调用模式call与apply

    编程语言的几个出发点 变量,基础语法 ,函数作用域 面向对象 1.函数的四种调用模式 函数模式 方法模式 构造器...

  • 作用域链&&严格模式

    作用域链 迷惑性代码 不假思索的想到 输出的一定是 200啊 ,然而结结实实被打脸,输出 100 原因 在编译时,...

  • JavaScript - 严格模式 - 作用域

    今天先从一个小案例说起,面向对象的内容已经过去一半,剩下的内容也至关重要 ! 希望帮到你的朋友, 能持续关注更新 ...

  • javaScript中this的指向

    this的指向 全局作用域 无论是否在严格模式下,在全局执行环境中(在任何函数体外部)this 都指向全局对象。 ...

  • 面向对象三、作用域

    title: 面向对象三、作用域date: 2017-06-17 10:10:13tags: javascript...

网友评论

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

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