美文网首页
「JS」变量作用域

「JS」变量作用域

作者: Rella7 | 来源:发表于2018-10-10 15:33 被阅读0次
  • 作用域介绍
    • 静态作用域
    • 动态作用域
  • JavaScript 变量作用域
    • 词法环境
      • 组成
      • 创建
      • 结构
    • 关于词法环境的问题
    • with 语句
    • try-catch 句法
    • 带名称的函数表达式

变量作用域

变量的作用域值的是变量的生命周期和作用范围(全局与局部作用域的区别)。

作用域介绍

静态作用域

静态作用域有称为词法作用域,即指其在编译的阶段就可以决定变量的引用。静态作用域只更变量定义的位置有关与代码执行的顺序无关。

var x = 0;
function foo() {
  alert(x);
}

function bar() {
  var x = 20;
  foo();
}

foo();
scope-lexical-scope.png

动态作用域

动态作用域的变量引用只可在程序运行时刻决定(其通常通过动态栈来进行管理)。

var x = 0;
function foo() {
  alert(x);
}

function bar() {
  var x = 20;
  foo();
}

foo();
scope-dynamic-scope.gif

JavaScript 变量作用域

JavaScript (1)使用静态作用域,(2)其没有块级作用域(只有函数作用域,就是只有 function 用于可以定义作用域),(3)在 ES5 之作使用词法环境来管理作用域。

词法环境

组成

词法环境用来描述静态作用域的数据结构。它由环节记录外部词法环境的引用组成。

  • 环境记录(record)(指形参,变量,函数等)
  • 外部词法环境的引用(outer)
创建

在一段代码执行之前,先初始化词法环境。会被初始化的有:

  • 形参
  • 函数定义(创建函数对象,会保存当前作用域。见下图)
  • 变量定义(所有初始化值均为 undefined
scope-function-init.png
结构
var x = 10;
function foo(y) {
  var z = 30;
  function bar(q) {
    return x + y + z + q;
  }
  return bar;
}
var bar = foo(20);
bar(40);

全局词法作用域(初始化状态)

scope-global-init.png

函数词法作用域

scope-structure.jpg

关于词法环境的问题

命名冲突

形参,函数定义,变量名称命名冲突。其中的优先级的排序如下:

函数定义 > 形参 > 变量

arguments 的使用

为函数中定义好的变量。

函数表达式与函数定义的区别

  • 函数表达式是在执行时才创建函数对象。
  • 函数定义为在代码执行之前就进行创建的。

with 语句

with 会创造一个临时作用域。

var foo = 'abc';
with({
  foo: 'bar';
}) {
  function f() {
    alert(foo);
  };
  (function() {
    alert(foo);
  })();
  f();
}

try-catch 句法

try {
  var e = 10;
  throw new Error();
} catch (e) {
  function f() {
    alert(e);
  }
  (function() {
    alert(e);
  })();
  f();
}

带名称的函数表达式

当一个函数表达式有了名称之后,JavaScript 会创建一个新的词法环境。并在这个词法环境中用有一个属性 A 指向这个函数,同时这个属性 A 指向的函数是不可被修改的。

下面例子为不常规的写法

(function A(){
  A = 1;
  alert(A);
})();
scope-function-with-name.png

相关文章

  • 变量作用域

    变量作用域:静态作用域、动态作用域JS变量作用域:JS使用静态作用域JS没有块级作用域(全局作用域、函数作用域等)...

  • js中作用域与作用域链

    js中作用域与作用域链 作用域 *作用域基本概念 作用域一般指变量的作用范围,变量分为全局变量和局部变量,对应的作...

  • 作用域与变量提升

    作用域与变量提升 作用域 JS中变量的作用域有全局作用域和局部作用域两种,作用域简单来讲就是变量与函数的可访问范围...

  • 闭包

    导学:变量作用域:全局作用域、局部作用域 js中,函数内部可以直接读取全局变量 *链式作用...

  • JavaScript快速上手:关于闭包的知识分享

    JS中变量的作用域 在理解闭包之前,我们得弄清楚JS中变量的作用域原理,它分为全局作用域和局部作用域,它有一...

  • JavaScript快速上手:关于闭包的知识分享

    01 JS中变量的作用域 在理解闭包之前,我们得弄清楚JS中变量的作用域原理,它分为全局作用域和局部作用域,它有一...

  • 浅谈JS作用域链

    浅谈JS作用域链 作用域 作用域(scope)就是变量访问规则的有效范围。作用域外,无法引用作用域内的变量;离开作...

  • JS高级-闭包、沙箱

    作用域,作用域链,预解析 变量:局部变量、全局变量 作用域:变量的使用范围 js中没有块级作用域,一对括号中定义的...

  • JavaScript作用域学习笔记

    @(JS技巧)[JavaScript, 作用域] JavaScript作用域学习笔记 概念: 作用域就是变量与函数...

  • 2019-08-13JS里面的作用域Scope

    作用域指一个变量的作用范围。 JS的作用域 在JS中,有两种作用域 全局作用域直接编写在script标签中 JS代...

网友评论

      本文标题:「JS」变量作用域

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