执行上下文

变量提升与函数提升

变量声明提升

  • 通过var定义(声明)的变量--在定义语句之前就可以访问到
  • 值为undefined
console.log(a);	//undefined
var a = 1;
//执行顺序
var a;
console.log(a);
a = 1;

函数声明提升

  • 通过function声明的函数--在之前就可以直接调用
  • 值为函数定义(对象)
fn();//可调用
function fn(){
    conse.log('哈哈');
}

执行上下文

代码分类--位置

全局代码

函数(局部)代码

全局执行上下文

  • 在执行全局代码前将window确定为全局执行上下文

    • 对全局数据进行预处理
    • var定义的全局变量-->undefined--添加为window的属性
    • function声明的全局函数-->赋值--添加为window的方法
    • this-->赋值window
    • 开始执行全局代码
    //全局执行上下文
    console.log(a1, window.a1);  //undefined undefined
    a2();   //a2();
    console.log(this);  //window
    var a1 = 3;
    function a2() {
        console.log('a2()');
    }
    console.log(a1);
    

函数执行上下文

  • 在调用函数--准备执行函数体之前--创建对应的函数执行上下文对象--虚拟的,存在于栈中

    • 对局部数据进行预处理
    • 形参变量-->赋值(实参)--添加为执行上下文的属性
    • arguments-->赋值(实参列表)--添加为执行上下文的属性
    • var定义的局部变量-->underfined--添加为执行上下文的属性
    • this-->赋值(调用函数的对象)
    • 开始执行函数体代码
    //函数执行上下文
    function fn(a1) {
        console.log(a1);    //2
        console.log(a2);    //undefined
        a3();   //a3
        console.log(this);  //window
        console.log(arguments); //2,3
        var a2 = 4;
        function a3() {
            console.log('a3');
        }
    }
    fn(2, 3);
    

执行上下文栈

  • 在全局代码执行前--JS引擎会创建一个栈来存储管理所有的执行上下文对象
  • 在全局执行上下文(window)确定后--将其添加到栈中(压栈)
  • 在函数执行上下文创建后--将其添加到栈中(压栈)
  • 在当前函数执行完后--将栈顶的对象移除(出栈)
  • 当所有代码执行完成后--栈中只剩下window
<script>
    //执行全局上下文
	var a = 10;
	var bar = function (x) {
   		var b = 5;
    	foo(x + b); //进入foo执行上下文
	}
	var foo = function (y) {
    	var c = 5;
    	console.log(a + c + y);
	}
	bar(10);    //进入bar函数执行上下文
</script>

执行上下文

面试题

console.log('gb:' + i);
var i = 1;
foo(1);
function foo(i) {
    if (i == 4) {
        return;
    };
    console.log('fb:' + i);
    foo(i + 1);
    console.log('fe:' + i);
}
console.log('ge:' + i);

执行上下文

function a(){};
var a;
console.log(a); //f a(){}--变量先被提升--函数覆盖变量后提升
if(!(b in window)){
    var b = 1;
}
console.log(b); //undefined--变量先被提升为全局变量
var c = 1;
function c(c){
    var c = 3;
}
c(2);   //报错--变量先被提升--函数后被提升--变量最后被赋值--因此不是函数,不能被调用

原文链接:https://www.cnblogs.com/Liu-h/p/17337906.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:执行上下文 - Python技术站

(0)
上一篇 2023年4月22日
下一篇 2023年4月22日

相关文章

  • JS如何通过FileReader获取.txt文件内容

    获取.txt文件内容的完整攻略可以分为以下几个步骤: 获取input标签上传的文件对象。 利用JavaScript中的FileReader API读取文件内容。 将文件内容进行处理展示。 下面我们分别介绍每个步骤的具体实现。 第一步:获取上传的文件对象 在HTML中,我们可以通过input标签来实现文件上传功能。例如: <label for=&quot…

    JavaScript 2023年5月27日
    00
  • 从JavaScript纯函数解析最深刻的函子 Monad实例

    让我给你讲解一下“从JavaScript纯函数解析最深刻的函子Monad实例”的完整攻略。 1. 函数式编程简介 在开始解析函子Monad之前,我们需要先了解一些函数式编程的基础概念。函数式编程是一种编程风格,其核心思想是将计算过程尽可能的使用函数来描述和实现。在函数式编程中,函数是一等公民,也就是说函数可以像其他数据类型一样被传递、赋值、作为参数或返回值等…

    JavaScript 2023年5月28日
    00
  • JS实现获取数组中最大值或最小值功能示例

    JS实现获取数组中最大值或最小值功能示例 获取数组中的最大值或最小值是在开发中经常用到的功能。JS提供了一些方法来实现这一功能,本文将详细介绍如何获取数组中的最大值和最小值,以及示例说明。 Array.prototype.sort() JS提供了Array.prototype.sort() 方法来对数组中的元素进行排序,我们可以使用sort()方法将数组元素…

    JavaScript 2023年5月28日
    00
  • js数组的基本使用总结

    JS数组的基本使用总结 什么是数组 数组是一种特殊的对象,可以用来存储一组有序的数据。数组的每个元素都有一个索引,以此来确定元素在数组中的位置。 创建和使用数组 在JavaScript中,我们可以使用以下两种方式来创建数组: 直接声明 let arr = [1, 2, 3, 4, 5]; 通过构造函数创建 let arr = new Array(1, 2, …

    JavaScript 2023年5月27日
    00
  • JS中的算法与数据结构之栈(Stack)实例详解

    JS中的算法与数据结构之栈(Stack)实例详解 什么是栈? 栈(Stack)是一种遵从后进先出(LIFO)原则的有序集合,是一种线性数据结构,只允许在栈顶进行插入和删除操作。 如何实现栈? JavaScript中可以通过数组来实现栈,使用数组的pop()、push()方法可以轻松地实现栈的相关操作。 创建一个栈(Stack)类 class Stack { …

    JavaScript 2023年5月27日
    00
  • 使用JS正则表达式 替换括号,尖括号等

    使用JS正则表达式替换括号、尖括号等的完整攻略分为以下几个步骤: 定义正则表达式 使用replace()函数替换匹配到的字符串 将替换后的字符串返回 下面是两个示例说明: 示例一 我们要将以下HTML代码中的所有尖括号<、>用[]代替 <div class="container"> <h1>Welcom…

    JavaScript 2023年6月10日
    00
  • JS Array.slice 截取数组的实现方法

    JS Array.slice截取数组常用于从数组中获取一部分数组元素。以下是完整的攻略,包括:定义、参数、返回值、示例说明、应用场景等。 定义 Array.slice是数组的一个方法,用于截取数组的一部分,返回截取后的新数组,而不会修改原数组。 语法 array.slice(start, end) 参数 start:要截取的开始下标,从0开始。 end:要截…

    JavaScript 2023年5月27日
    00
  • JavaScript数据存储 Cookie篇

    下面是JavaScript数据存储之Cookie篇的完整攻略。 什么是Cookie Cookie 是一种在客户端存储数据的机制,通过浏览器将数据存储在用户的计算机上。Cookie 通常由 Web 服务器生成,以便服务器可以记住用户的状态,从而改善用户对网站的体验。 Cookie 的属性 Cookie 有以下几个属性: 名称:Cookie 的名称。 值:Coo…

    JavaScript 2023年6月11日
    00
合作推广
合作推广
分享本页
返回顶部