方法的入栈和出栈

一.作用域问题

1.全局作用域

在全局都能进行访问的变量

javascript 复制代码
  var a = 10;
    function fn() {
      var b = 20;
      return a + b;
    }
    console.log(fn());

2.局部的作用域

只能在限定的范围内进行访问

javascript 复制代码
 function fn() {
      var b = 20;
    }
    console.log(b);

b is not defined 打印的结果是b这个变量没用定义

3.块级作用域

(1)使用var

javascript 复制代码
  for (var i = 0; i <= 5; i++) {}
    console.log(i);
   

打印的结果是:6

(2)使用let

javascript 复制代码
  for (let i = 0; i <= 5; i++) {}
    console.log(i);

i is not defined

这里使用let定义变量就使用到了es6的let语法,块级作用域,使用let定义的变量只能在let{}包裹的快中就行访问

4.作用域的查找规则

代码1:

javascript 复制代码
   function fn() {
      var a = 10;
      return function fn1() {
         var a=11
         console.log(a);
      };
    }
    var b = fn();
    b()
    b()
    b()

首先在自己的作用域进行查找,如果没用找到就会往行上一级的作用域进行查找,直到找不为止。

代码2:

javascript 复制代码
  function fn() {
      var a = 10;
      return function fn1() {
        console.log(a++);
      };
    }
    var b = fn();
    b()  //10
    b()  //11
    b()  //12

二.通过方法的进栈和出栈来看闭包

javascript 复制代码
    function fn() {
      var a = 10;
      return console.log(a);
    }
    fn();
    fn();

fn方法入栈,在只想完毕后,就会销毁a这个变量。

javascript 复制代码
  function fn() {
      var a = 10;
      return function fn1() {
        console.log(a++);
      };
    }
    var b = fn();
    b()  //10
    b()  //11
    b()  //12

这个方法调用fn函数,返回fn1这个函数但是fn1这个函数里面的变量a没有指向的对象,因此它指向fn函数的a=10,调用fn()函数按照以往的逻辑本应该将a这个变量进行销毁,返回的也是一个可调用的b函数,因为b函数中的a变量需要fn函数定义的变量,所以不会被销毁。

因此没调用一次fn函数a机会递增1,.这也是不建议使用必要的原因,因为会造成栈溢出

相关推荐
jf加菲猫2 分钟前
第10章 数据处理
xml·开发语言·数据库·c++·qt·ui
酉鬼女又兒5 分钟前
零基础快速入门前端深入掌握箭头函数、Promise 与 Fetch API —— 蓝桥杯 Web 考点全解析(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·css·职场和发展·蓝桥杯·es6·js
迷藏4948 分钟前
**发散创新:Go语言中基于上下文的优雅错误处理机制设计与实战**在现代后端开发中,**错误处理**早已不是简单
java·开发语言·后端·python·golang
2301_764441338 分钟前
基于python实现的便利店投资分析财务建模评估
开发语言·python·数学建模
杰克尼11 分钟前
知识点总结--day10(Spring-Cloud框架)
java·开发语言
程序员小寒12 分钟前
JavaScript设计模式(七):迭代器模式实现与应用
前端·javascript·设计模式·迭代器模式
晓131312 分钟前
React篇——第七章 React 19 编译器深度解析
前端·javascript·react.js
im_AMBER17 分钟前
手撕代码之事件委托
前端·javascript·面试
okiseethenwhat18 分钟前
Java 内部类详解
java·开发语言
枫叶丹418 分钟前
【HarmonyOS 6.0】ArkUI 状态管理进阶:深入理解 @Consume 装饰器默认值特性
开发语言·华为·harmonyos