首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JS学习系列 02 - 词法作用

两种作用作用”我们知道是一套规则,用来管理引擎如何在当前作用以及嵌套的子作用域中根据标识符名称进行变量查找。 作用有两种主要工作模型:词法作用和动态作用。...大多数语言采用的都是词法作用,少数语言采用动态作用(例如 Bash 脚本),这里我们主要讨论词法作用。 2. 词法 大部分标准语言编译器的第一个工作阶段叫作词法化。...简单地说,词法作用是由你在写代码时将变量和函数(块)作用写在哪里来决定的。当然,也会有一些方法来动态修改作用,后边我会介绍。...总结来说,无论函数在哪里被调用,也无论它如何被调用,它的词法作用都只由函数被声明时所处的位置决定。 3. 欺骗词法 JavaScript 中有 3 种方式可以用来“欺骗词法”,动态改变作用。...之后的代码时,引擎并不知道或在意前面的代码是以动态形式插入进来并对词法作用环境进行修改的,引擎只会像往常一样正常进行词法作用的查找。

1.1K30

词法作用

词法阶段 ---- 大部分标准语言编译器的第一个工作阶段叫做词法化。词法化的过程会对源代码中的字符进行检查,如果是有状态的解析过程,还会赋予单词语义。 词法作用就是定义在词法阶段的作用。...词法作用是由你在写代码时将变量和块作用下载哪里来决定的。 作用查找会在找到第一个匹配的标识符时停止。在多层的嵌套作用域中可以定义同名的标识符,这叫做“遮蔽效应”。...无论函数在哪里被调用,他的词法作用只由函数被声明时所处的位置决定。 词法作用查找只会查找一级标识符。...欺骗词法(修改词法作用) ---- 欺骗词法作用会导致性能下降。...性能 ---- JS引擎会在编译阶段进行数项的性能优化。其中有些依赖于能够根据代码的词法进行静态分析,并预先确定所有变量和函数的定义位置,才能在执行过程中快速找到标识符。

56820
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    词法作用

    词法作用 作用共有两种主要的工作模式,第一种最为普遍,被大多数编语言所采用的词法作用,另一种叫做动态作用,仍有一些编程语言在使用(Bash脚本、Perl中的一些模式等) 大多数标准语言编译器的第一个工作阶段叫作词法化...词法作用就是定义在词法阶段的作用,由 变量和作用的位置 来决定的,因此当词法分析器处理代码时会保持作用不变(大部分情况是这样) // 三层嵌套的作用 // 作用气泡由其对应的作用代码块写在哪里决定的...无论函数在哪里被调用,且无论它如何被调用,它的词法作用都只有函数被声明所处的位置决定。 注:词法作用只会查找一级标识符,比如a 。...欺骗词法 如果说词法作用完全由写代码期间函数所声明的位置来定义,怎样才能在运行时来“修改”词法作用?...,遮蔽了外部全局作用域中的同名变量 但是在 严格模式 中,eval()在运行时有自己的词法作用,意味着其中的声明无法修改所在的作用 with with 通常被当作重复引用同一个对象中的多个属性的快捷方式

    53710

    JavaScript执行机制:变量提升、作用链、词法作用、块级作用、闭包和this

    本文将围绕JavaScript中的变量提升、作用链、词法作用、块级作用、闭包和this进行详细介绍。...这是因为作用链的查找机制。 1.2 词法作用 词法作用是JavaScript中作用的静态结构。词法作用是在代码编写时就确定的,与代码的执行无关。...换句话说,词法作用是由函数的嵌套结构决定的,而不是函数的调用方式。 词法作用使得JavaScript引擎可以在编译阶段就确定变量的查找顺序。这种静态结构有助于提高代码的可读性和可维护性。...return bar; } var baz = foo(); baz(); // 1 在这个示例中,bar函数在foo函数的作用内定义,因此它的词法作用包含了foo函数的作用。...当baz函数被调用时,它可以访问foo函数作用内的变量x,即使foo函数已经执行完毕。这是因为词法作用的静态结构。 1.3 块级作用 块级作用是指由大括号{}包围的代码块内的作用

    11810

    JS作用作用

    JS中的作用就是在一定的空间范围内对数据进行读写操作。 在JS中一个变量的作用(scope)是程序中定义这个变量的区域。 变量有全局变量和局部变量两种。...下面就要借助JS作用链来更好的理解作用了。 在此之前,先要明确个概念,即执行环境和作用是两个完全不同的概念。 函数的每次调用都有与之紧密相关的作用和执行环境。...搜索过程始终从作用链的前端开始,然后逐级地向后(全局执行环境)回溯,直到找到标识符为止。 此外还要讲下JS作用域中的块级作用JS中是没有块级作用这个概念的。 什么是块级作用呢?...但JS由于没有块级作用,所以在块外仍旧可以访问。...JS并不支持块级作用,它只支持函数作用,而且在一个函数中的任何位置定义的变量在该函数中的任何地方都是可见的。 那么JS又该怎么拥有块级作用呢?

    4.1K30

    JavaScript 词法作用不完全指北

    在 JavaScript 作用不完全指北中,我们介绍了作用的概念以及 JavaScript 引擎、编译器和作用的关系。作用有两种主要的工作模型:词法作用和动态作用。...其中最为普遍的也是大多数编程语言所采用的是词法作用,我们主要对其进行研究学习。 在传统编译语言的流程中, 程序中的一段源代码在执行之前会经历三个步骤, 统称为“编译”。...第一个步骤也叫作词法化,词法作用就是定义在词法阶段的作用。简单地说,词法作用是由你写代码时将变量和块作用写在哪里来决定的,词法分析器处理代码时会保持作用不变。...我们通过以下代码来分析一下词法作用: function foo(a){ var b = a * 2; function bar(c){ console.log(a,b,c); }...也就是说,在多层的嵌套作用域中可以定义同名的标识符,内部的标识符会遮蔽外部的标识符,这叫作“遮蔽效应”。 词法作用意味着作用是由书写代码时函数的位置来决定的。

    38720

    JS基础——作用作用

    作用 [[scope]],函数定义时自动生成的一个隐式属性,是用来存储函数作用链 Scope Chain的容器。作用链是用来存储函数执行上下文 AO和全局执行上下文 GO的容器。...函数被定义时,系统会为函数生成[[scope]],[[scope]]中保存该函数的作用链,并从该作用链的起始位置开始存储当前环境的作用链。...函数被定义后&将要执行前会生成函数本身的AO,并将其插入作用链的起始位置。...,并将GO插入到作用链的起始位置。...函数a被执行时,此时函数b也被定义,函数b的[[scope]]也在此时生成,其中存储函数b的作用链,并将当前环境的作用链插入函数b作用链的起始位置,即函数a的AO和GO。

    3.5K10

    Js篇-面试题1-有关变量-词法块级作用

    var foo = "test" 答案: undefined 解析: 变量foo,相当于只有var foo;但是却没有赋值,所以值是undefined,并且变量的声明并不会提升,只有函数声明会提升 词法作用...if(false) { var temp = 456 } } f(); 答案: undefined 解析: 在没有调用 f 函数时,temp的值是123,在查找变量时,它先会从函数内沿着作用链逐级向外进行查找...,若有则会返回,若无,则会返回undefined, 使用var声明的变量并不会有块级作用,在if语句块声明赋值的变量,相当于是裸露的,因为在 f函数内,变量先使用,但是未赋值,所以是undeifined...块级作用 写出下面一段代码输出的结果 var temp = 123; function f() { console.log(temp); if(true) { console.log...答案: 123,然后报错ReferenceError: Cannot access 'temp' before initialization,无法在初始化之前访问变量 解析: let声明的变量是有块级作用

    40110

    JS进阶:作用作用

    作用(Scope) 1.什么是作用 作用是在运行时代码中的某些特定部分中变量,函数和对象的可访问性。换句话说,作用决定了代码区块中变量和其他资源的可见性。...全局作用有个弊端:如果我们写了很多行 JS 代码,变量定义都没有用函数包括,那么它们就全部都在全局作用域中。这样就会 污染全局命名空间, 容易引起命名冲突。...因为放在里面的所有变量,都不会被外泄和暴露,不会污染到外面,不会对其他的库或者 JS 脚本造成影响。这是函数作用的一个体现。...); // logs 'Hammad' JS 的初学者经常需要花点时间才能习惯变量提升,而如果不理解这种特有行为,就可能导致 bug 。...我们知道JavaScript属于解释型语言,JavaScript的执行分为:解释和执行两个阶段,这两个阶段所做的事并不一样: 解释阶段: 词法分析 语法分析 作用规则确定 执行阶段: 创建执行上下文

    2.6K20

    了解 JS 作用作用

    JS中使用的是词法作用(lexical scope) 不在任何函数内声明的变量(函数内省略var的也算全局)称作全局变量(global scope) 在函数内声明的变量具有函数作用(function...,就是说函数是一个作用的基本单位,js不像c/c++那样具有块级作用 比如 if  for 等 function test(){ for(var i=0;i<10;i++){ if(i=...JS中的声明提前 js中的函数作用是指在函数内声明的所有变量在函数体内始终是可见的。...引入一大段话来解释: 每一段js代码(全局代码或函数)都有一个与之关联的作用链(scope chain)。 这个作用链是一个对象列表或者链表,这组对象定义了这段代码中“作用域中”的变量。...作用链举例: 在js最顶层代码中(也就是不包括任何函数定义内的代码),作用链由一个全局对象组成。

    2K10

    js作用详解

    atest其实是一个window对象下的方法对象 var 局部变量作用 var 声明一个对象,只作用当前作用以下。...变量作用覆盖问题 通过var 关键字我们知道,当声明一个变量时,该变量可以被当前作用,以及下层作用访问 当下层作用存在同名变量时,下层变量将覆盖上层变量:     var a=...同时,在子作用声明的方法,只能在当前作用或者下层作用调用 闭包函数,闭包作用 闭包函数,又称匿名函数,例如:     (function () {         var a...在闭包函数中声明的变量,只能在闭包函数内的作用,以及下层作用使用,可通过return 对象中,通过return对象中声明的方法进行返回,使得上级作用能成功访问到闭包作用的变量 return作用变量访问情况...2:js作用是往下通用的,下层作用可访问上层作用的变量,并可修改值 3:js下层作用变量和上层同名冲突时,下层作用将覆盖上层变量,但上层作用的访问不受影响 4:不适用var方法定义的变量,

    2.5K10

    原生JS | 作用

    HTML5学堂-码匠:作用那些必须掌握的知识,还有大量作用案例练习与分析,快快进来! 作用的基础知识 在JavaScript中,每个变量会有一个有效区域(范围),这个就是作用。...一个变量在其作用内是可以被访问的,在作用域外不能被访问。 全局作用与局部作用 变量的执行环境有两种:一种是全局,另一种是局部(如:放在函数里面)。...如果window下也不存在该空间,会在全局作用之下进行空间的创建。 作用链 由于在全局作用当中会包含局部作用,局部作用当中还可以再包含局部作用。...当有多层作用时,深层的作用域中查找变量时,会按照“当前作用”到“上层作用”再到“全局作用”的顺序进行查找,这个查找的顺序就可以理解为作用链。...var进行变量的声明,此时在函数这个局部的作用当中,并没有user这个存储空间,之后按照“作用链”向上翻找,也就是在全局(window)作用当中进行查找。

    4.8K50

    js中的作用

    前言 相信自从es6出来之后,你一定多少知道或者已经在项目中实践了部分的块级作用,在函数或者类的内部命名变量已经在使用let了,但是你知道它真正的作用是什么吗?...又是因为什么我们要用这个块级作用,本文与你一起探讨块级作用的场景以及所有细节问题。...es6之前的作用 特点1 :js只有函数级作用以及全局两种 特点2 :不通过var声明的变量直接赋值也可以用并且可以访问,原理是直接赋值到了window对象属性变量下,两者如果同时定义,那么会覆盖使用...,函数内可以访问外部作用,而全局是不可以访问函数作用内的变量或者方法的 var a=b=c=12 function demo(){ var z=13 console.log(b)//12...块级作用 场景一 循环中的块级作用 如果我们有一个遍历循环的绑定事件,并且需要把当前的指针绑定到对应方法中。

    3.2K20

    JS学习系列 03 - 函数作用和块作用

    在 ES5 及之前版本,JavaScript 只拥有函数作用,没有块作用(with 和 try...catch 除外)。在 ES6 中,JS 引入了块作用,{ } 内是单独的一个作用。...采用 let 或者 const 声明的变量会挟持所在块的作用,也就是说,这声明关键字会将变量绑定到所在的任意作用域中(通常是 {...} 内部)。 今天,我们就来深入研究一下函数作用和块作用。...函数中的作用 函数作用的含义是指,属于这个函数的任何声明(变量或函数)都可以在这个函数的范围内使用及复用(包括这个函数嵌套内的作用)。...块作用 ES5 及以前 JavaScript 中具有块作用的只有 with 和 try...catch 语句,在 ES6 及以后的版本添加了具有块作用的变量标识符 let 和 const 。...总结 函数是 JavaScript 中最常见的作用单元。块作用指的是变量和函数不仅可以属于所处的函数作用,也可以属于某个代码块。

    1.6K10
    领券