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

JS作用作用

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

4.1K30

JS作用作用

一、作用分为块级作用、全局作用、函数作用作用就是一个独立的地盘,让变量不会外泄、暴露出去。也就是说作用最大的用处就是隔离变量,不同作用下同名变量不会有冲突。...二、作用链当前作用没有定义的变量,这成为自由变量 。需要向父级作用寻找(注意:这种说法并不严谨,作用域中取值,这里强调的是“创建”,而不是“调用”,切记切记,其实这就是所谓的"静态作用"。)。...三、面试真题:const food = "rice";const eat = function () { console.log(`eat ${food}`);};(function () { const...${food}`);};(function () { food = "noodle"; eat(); // eat rice})();console.log(`eat ${food}`); //...eat noodlevar x = 10function fn() { console.log(x)}function show(f) { var x = 20; (function () {

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

JS基础——作用作用

作用 [[scope]],函数定义时自动生成的一个隐式属性,是用来存储函数作用链 Scope Chain的容器。作用链是用来存储函数执行上下文 AO和全局执行上下文 GO的容器。...函数被定义时,系统会为函数生成[[scope]],[[scope]]中保存该函数的作用链,并从该作用链的起始位置开始存储当前环境的作用链。...实例分析 function a() { function b() { var b = 2; } var a = 1;...b(); } var c = 3; a(); 复制代码 函数a被定义时,会为a生成[[scope]]属性,其中存储a的作用链,并将GO插入到作用链的起始位置。...函数a被执行时,此时函数b也被定义,函数b的[[scope]]也在此时生成,其中存储函数b的作用链,并将当前环境的作用链插入函数b作用链的起始位置,即函数a的AO和GO。

3.5K10

JS作用

JavaScript的作用有全局作用和局部作用 先通过一下代码来体验下作用 var x = 1; function f1(){ var y = 2; x = 10; console.log...undefined 就是报如下的错误,也就是y是个未定义的变量 VM42:7 Uncaught ReferenceError: y is not defined at :7:13 上述代码中变量x就是全局作用...,方法f1的作用也是全局,f1方法中的变量y是局部的,y的作用范围仅限f1方法体内,离开了f1的方法体的作用范围,就无法获取到y的值,所以上述的例子中最后打印y的时候是undefined 我们再来看下面的例子...var a = 1; function f1(){ console.log(a); //1 a = 3; } f1(); console.log(a); //3 上述代码能正常运行...---------------------------------------------- 1 是不是跟大家想的不一样,让我们来分析一下这段代码的预解析过程 1)首先定义了一个全局变量a 2)定义了function

8410

JS进阶:作用作用

全局作用有个弊端:如果我们写了很多行 JS 代码,变量定义都没有用函数包括,那么它们就全部都在全局作用域中。这样就会 污染全局命名空间, 容易引起命名冲突。...因为放在里面的所有变量,都不会被外泄和暴露,不会污染到外面,不会对其他的库或者 JS 脚本造成影响。这是函数作用的一个体现。...); // logs 'Hammad' JS 的初学者经常需要花点时间才能习惯变量提升,而如果不理解这种特有行为,就可能导致 bug 。...var x = 10 function fn() { console.log(x) } function show(f) { var x = 20 (function() { f()...作用域中取值,这里强调的是“创建”,而不是“调用”,切记切记——其实这就是所谓的"静态作用" var a = 10 function fn() { var b = 20 function bar

2.5K20

了解 JS 作用作用

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

2K10

js作用详解

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

2.5K10

js中的作用

又是因为什么我们要用这个块级作用,本文与你一起探讨块级作用的场景以及所有细节问题。...es6之前的作用 特点1 :js只有函数级作用以及全局两种 特点2 :不通过var声明的变量直接赋值也可以用并且可以访问,原理是直接赋值到了window对象属性变量下,两者如果同时定义,那么会覆盖使用...,函数内可以访问外部作用,而全局是不可以访问函数作用内的变量或者方法的 var a=b=c=12 function demo(){ var z=13 console.log(b)//12...块级作用 场景一 循环中的块级作用 如果我们有一个遍历循环的绑定事件,并且需要把当前的指针绑定到对应方法中。...(temp){ return function(){ console.log(temp) } })(i) } arr[2]()//2 //解决方案 2 块级作用 ,利用let

3.2K20

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

在 ES5 及之前版本,JavaScript 只拥有函数作用,没有块作用(with 和 try...catch 除外)。在 ES6 中,JS 引入了块作用,{ } 内是单独的一个作用。...采用 let 或者 const 声明的变量会挟持所在块的作用,也就是说,这声明关键字会将变量绑定到所在的任意作用域中(通常是 {...} 内部)。 今天,我们就来深入研究一下函数作用和块作用。...函数中的作用 函数作用的含义是指,属于这个函数的任何声明(变量或函数)都可以在这个函数的范围内使用及复用(包括这个函数嵌套内的作用)。...总结来说,作用可以起到两个作用: 私有化变量或函数 规避同名冲突 1.2 函数声明和函数表达式 如果 function 是声明中的第一个词,那么就是一个函数声明,否则就是一个函数表达式。...总结 函数是 JavaScript 中最常见的作用单元。块作用指的是变量和函数不仅可以属于所处的函数作用,也可以属于某个代码块。

1.6K10

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

在 ES5 及之前版本,JavaScript 只拥有函数作用,没有块作用(with 和 try...catch 除外)。在 ES6 中,JS 引入了块作用,{ } 内是单独的一个作用。...采用 let 或者 const 声明的变量会挟持所在块的作用,也就是说,这声明关键字会将变量绑定到所在的任意作用域中(通常是 {...} 内部)。 今天,我们就来深入研究一下函数作用和块作用。...函数中的作用 函数作用的含义是指,属于这个函数的任何声明(变量或函数)都可以在这个函数的范围内使用及复用(包括这个函数嵌套内的作用)。...总结来说,作用可以起到两个作用: 私有化变量或函数 规避同名冲突 1.2 函数声明和函数表达式 如果 function 是声明中的第一个词,那么就是一个函数声明,否则就是一个函数表达式。...总结 函数是 JavaScript 中最常见的作用单元。块作用指的是变量和函数不仅可以属于所处的函数作用,也可以属于某个代码块。

9410

JS作用与闭包

JS作用分为全局作用和函数作用。 2|0全局作用 全局作用在页面打开时创建,在页面关闭时销毁。...3|0函数作用 调用函数时创建函数作用,函数执行完毕后,函数作用销毁。 每调用一次函数就会创建一个新的函数作用,他们之间是互相独立的。...在函数作用域中,可以访问到全局作用的变量,在全局作用域中无法访问到函数作用的变量。...当在函数作用操作一个变量时,会现在自身作用域中寻找,如果有就直接使用,如果没有则向上一级作用域中寻找在函数作用域中也有声明提前的特性使用var关键字声明的变量,会在函数中所有的代码执行之前被声明 function...function fun4(){ myName = "xiaoming"; } 4|0作用链 在介绍作用链之前我们需要了解以下几个概念: ①执行环境(execution context): 定义了变量或函数有权访问的其他数据

1.9K20

JS作用(入门篇)

这套规则被称为作用js作用规则并不像其他语言(比如 c、java 等)那么严谨,甚至很多时候还会让新手一头雾水。...本文要讲作用有以下几个: 全局作用(window / global) 函数作用function) 块状作用({}) 动态作用(this 粗略讲解) 本文主要探讨日常工作中需要了解的几个点,所以并不会深入讲解...变量与常量 在了解作用之前,需要先了解 js 的变量和常量是如何声明和使用。 js 的变量声明有 2 种:var 和 let。...点击查看 const 用法 全局作用 在 window 下声明的变量属于全局作用。 比如 var a = 123 与之相对的是 局部作用 ,比如 函数作用 、块状作用 等,下面会讲到。...动态作用 动态作用主要是指 this 。 动态作用不关心函数和作用是如何声明以及在何处声明的,它只关心从何处调用(箭头函数除外)。

94210

关于js作用问题详解

undefined var a; 3. console.log(a); // undefined var a = 10; 4. var a = 10; console.log(a); // 10 在一段js...用一个例子说明一下: var a = 10; function fn() { console.log(a); //a是自由变量 //函数创建时,就确定了a要取值的作用 } function bar...如上图,全局代码和fn、bar两个函数都会形成一个作用。而且,作用有上下级的关系,上下级关系的确定就看函数是在哪个作用下创建的。...例如,fn作用下创建了bar函数,那么“fn作用”就是“bar作用”的上级。...作用最大的用处就是隔离变量,不同作用下同名变量不会有冲突 例如以上代码中,三个作用下都声明了“a”这个变量,但是他们不会有冲突。各自的作用下,用各自的“a”。 作用和上下文环境 ?

1.8K30
领券