title: JS补充
categories: Javascript
tag:

  • with
  • eval
  • strict
    date: 2021-11-18 15:23:34

JS 额外知识

作用域,只有全局作用域和函数作用域

with 语句

with 也会形成自己的作用域。扩展一个语句的作用域链

  1. var obj = {
  2. name: 'hello'
  3. }
  4. //会现在with传入的对象里面查找
  5. with (obj) {
  6. console.log(name)
  7. }

9_JS补充 - 图1

不建议使用 with 语句,因为它可能是混淆错误和兼容性问题的根源。

eval 函数

eval 是一个特殊的函数,它可以将传入的字符串当做 JavaScript 代码来运行。

  1. var evalString = `var message='哈哈哈';console.log(message)`
  2. eval(evalString)

9_JS补充 - 图2

不建议在开发中使用 eval:

  • eval 代码的可读性非常的差(代码的可读性是高质量代码的重要原则);
  • eval 是一个字符串,那么有可能在执行的过程中被刻意篡改,那么可能会造成被攻击的风险;
  • eval 的执行必须经过 JS 解释器,不能被 JS 引擎优化;

认识严格模式

在 ECMAScript5 标准中,JavaScript 提出了严格模式的概念(Strict Mode)

  • 严格模式很好理解,是一种具有限制性的 JavaScript 模式,从而使代码隐式的脱离了 ”懒散(sloppy)模式“
  • 支持严格模式的浏览器在检测到代码中有严格模式时,会以更加严格的方式对代码进行检测和执行;

严格模式对正常的 JavaScript 语义进行了一些限制:

  • 严格模式通过 抛出错误 来消除一些原有的 静默(silent)错误;
  • 严格模式让 JS 引擎在执行代码时可以进行更多的优化(不需要对一些特殊的语法进行处理);
  • 严格模式禁用了在 ECMAScript 未来版本中可能会定义的一些语法;

开启严格模式

那么如何开启严格模式呢?严格模式支持粒度话的迁移:

  • 可以支持在 js 文件中开启严格模式;
  • 也支持对某一个函数开启严格模式;

严格模式通过在文件或者函数开头使用 use strict 来开启。

这里我们来说几个严格模式下的严格语法限制:

JavaScript 被设计为新手开发者更容易上手,所以有时候本来错误语法,被认为也是可以正常被解析的;

  • 但是这种方式可能给带来留下来安全隐患;
  • 在严格模式下,这种失误就会被当做错误,以便可以快速的发现和修正;
    1. 无法意外的创建全局变量
    2. 严格模式会使引起静默失败(silently fail,注:不报错也没有任何效果)的赋值操作抛出异常
    3. 严格模式下试图删除不可删除的属性
    4.严格模式不允许函数参数有相同的名称
    5. 不允许 0 的八进制语法
    6. 在严格模式下,不允许使用 with
    7. 在严格模式下,eval 不再为上层引用变量
    8. 严格模式下,this 绑定不会默认转成对象