IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> JavaScript普通函数调用与闭包调用 -> 正文阅读

[JavaScript知识库]JavaScript普通函数调用与闭包调用

JavaScript普通函数调用与闭包调用差异

今天是2022年2月4号,新年假期已经过去了七分之四,这几天杭州的天气xue微的不太好,阴天下雨的都持续一个月了,最近也下了几场小雪。

今天三喜临门,首先时女朋友的生日,然后也是2022年北京冬奥会开幕式,还是一个新的节气—立春。从今天开始,新的一年慢慢步入正规。

今天总结下普通函数的调用和闭包调用。

  1. 概念

    1. 函数执行时,每个执行上下文中都会有一个包含其中变量的对象。
    2. 【变量对象】全局上下文中叫变量对象,它会在代码执行期间始终存在。
    3. 【活动对象】函数局部上下文中的叫活动对象,只在函数执行期间存在。
    4. 作用域链的理解
  2. 普通函数执行

    1. function compare(value1,value2){
      	if(value1 < value2){
      		return -1;
      	}else if(value1 > value2){
      		return 1;
      	}else{
      		return 0;
      	}
      }
      let result =  compare(5,10);
      
    2. 上面示例中时一个日常使用的类型----暂且称为普通函数

      1. 在创建compare()函数时,就会预装载全局变量对象(compare,result)(保存在函数的的[[Scope]]属性中)。(像手机预装载软件一样,一出厂就有)
      2. 调用compare()函数时,会创建相应的执行上下文,并创建作用链(通过复制函数的[[Scope]]属性)
      3. 然后,会创建compare()函数的活动对象(arguments,value1,value2),并将其推入作用域链的前端
      4. 函数内部的代码在访问变量时,就会使用给定的名称从作用域链中查找。compare()函数,先访问活动对象,如果自己没有找到,再访问变量对象。
      5. 函数执行完后,局部活动对象会被销毁,内存中就只剩下全局作用域。
  3. 闭包执行

    1. function createComparisonFunction(propertyName){
      	return function(object1,object2){
      		let value1 = object1[propertyName];
      		let value2 = object2[propertyName];
      		if(value1 < value2){
      			return -1;
      		}else if(value1 > value2){
      			return 1;
      		}else{
      			return 0;
      		}
      	}
      }
      
    2. 闭包函数的执行流程

      1. 调用createComparisonFunction()后,返回匿名函数,此时的作用域包含全局上下文的变量对象和当前函数的活动对象。匿名函数就可以访问作用域链中的所有变量
      2. createComparisonFunction()执行完后,其执行的上下文作用域链会销毁。但是它的活动对象会保存在返回的匿名函数的作用域链中(和正常函数的差别)。直到匿名函数执行完后才会销毁。
      3. 闭包导致的问题
        1. 闭包会保留它们包含函数的作用域,所以比其他函数更占内存。
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-02-05 21:38:52  更:2022-02-05 21:40:31 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 2:06:47-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码