位置: 编程技术 - 正文

JavaScript基础篇(6)之函数表达式闭包(javascript入门基础)

编辑:rootadmin

推荐整理分享JavaScript基础篇(6)之函数表达式闭包(javascript入门基础),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript零基础,javascript基础入门教程,javascript零基础,javascript零基础,javascript 基础,javascript教程chm,javascript基础编程,javascript基础入门视频教程,内容如对您有帮助,希望把文章链接给更多的朋友!

其实js支持函数闭包的主要原因是因为js需要函数能够保存数据。这里的保存数据是只函数在运行结束以后函数内变量的值也会进行保存。至于为什么js需要在函数内可以保存数据,那就是js是一种函数式语言。在函数内保存数据是函数式语言的一大特征。

回顾前面介绍过的三种定义函数方式

functiosu(numnumreturnunum//函数声明语法定义vasufunction(numnum)returnunum}//函数表达式定义vasuneFunction("num""num""returnunum")//Functio构造函数

在分析闭包之前我们先来看看,定义和调用函数容易犯的错误。

例1:

例2:

例3:

在例1中,我们不能在使用函数声明式语法定义之前调用函数。解决方案:

1.如果使用函数表达式定义函数的话,需要在表达式定义后调用。

2.使用函数声明式。(这里浏览器引擎会 函数声明提升, 在所有代码执行之前先读取函数声明)

在例2中,我们预期的结果应该是打印1,实际结果是打印2。

为什么会这样?正因为 函数声明提升 ,所以浏览器在预解析的时候不会判断if条件,直接解析第二个函数定义的时候覆盖了第一个。

解决方案:

在例3中,发现只能只用fun1()调用,而不能使用fun2()调用。

我自己的理解,真正原因不知道。没找到资料。

因为1: function fun3() { }; 等效与 var fun3 = function fun3() { }; 如图:

所以只能只用fun1()调用,而不能使用fun2()调用。

其实这里我还是有疑问的?哪位大神知道,望告知。

既然,fun2在外面不能调用为什么在函数内部能调用?虽然在debugger还是得不到fun1。

JavaScript基础篇(6)之函数表达式闭包(javascript入门基础)

好了,通过上面的三道题目热身。我们继续今天的主题“闭包”。

1.什么是闭包?

定义:就是有权访问另一个函数作用域的变量的函数

我们先从一个示例函数开始:

例1:

例2:

例3:

显然,滥用闭包会增大内存的使用。所以非特殊情况尽量不要使用闭包。如果用到了,记得手动设置空引用,内存才能被回收 f = null ;

图解:(不了解作用域链的同学请先看前面的文章 作用域和作用域链 )

2.什么是匿名函数? (仅仅只是解释这个概念)

如:(即,没有名字的函数)

关于对象中函数的返回值是匿名函数时,this的怪异现象

讲解之前,先清醒下头脑,不要越看越迷糊了。如果迷糊了,那就直接忽略下面的。

obj.fun2();//打印结果"李四"意料之中的。obj.fun3()();//因为这里返回的是一个函数,所以要再加一对()来调用。打印结果是"张三",意料之外。//真是百事不得其解啊,什么this指向了全局?我们前面讲过“ 哪个对象点出来的方法,this就是哪个对象 ”,那我们的 obj.fun3()() 打印的是“张三”也就是说this执行了全局作用域。

我们看看下面的示例也许就知道为什么了。

我们来分解下 obj.fun3()() 先是 obj.fun3() 返回一个匿名函数到了window作用域,然后接着调用this就指向了window了。( 感觉解释有点勉强,也不知道对不,暂时自己先是这么理解的 )

闭包形成的原因:内存释放问题

一般,当函数执行完毕后,局部活动对象会被销毁,内存中仅保存全局作用域,但闭包的情况是不一样的。

闭包的活动对象依然会保存在内存中,于是像上例中,函数调用返回后,变量i是属于活动对象里面的,就是说其栈区还没有释放,但你调用c()的时候i变量保存的作用域链从b()->a()->全局去寻找作用域var i声明所在,然后找到了var i=1;然后在闭包内++i;结果,最后输出的值就是2了;

以上所述是小编给大家分享的JavaScript基础篇(6)之函数表达式闭包,希望大家喜欢。

JavaScript匿名函数之模仿块级作用域 匿名函数函数是JavaScript中最灵活的一种对象,这里只是讲解其匿名函数的用途。匿名函数:就是没有函数名的函数。函数的定义,首先简单介绍一下函

javascript性能优化之事件委托实例详解 本文实例分析了javascript性能优化之事件委托。分享给大家供大家参考,具体如下:为下面每个LI绑定一个click事件ulid="myLinks"liid="goSomewhere"Gosomewhere/liliid=

JavaScript文档碎片操作实例分析 本文实例分析了JavaScript文档碎片操作方法。分享给大家供大家参考,具体如下:使用文档碎片在某些情况下可以提高页面效率。javascript操作dom是一个很

标签: javascript入门基础

本文链接地址:https://www.jiuchutong.com/biancheng/387194.html 转载请保留说明!

上一篇:Express实现前端后端通信上传图片之存储数据库(mysql)傻瓜式教程(二)(express 前后端分离)

下一篇:JavaScript匿名函数之模仿块级作用域(javascript中的匿名函数)

  • 税额怎么调整
  • 地方教育附加税税率多少?
  • 人工费用分配表分配率
  • 未达起征点的增值税怎么做账
  • 增值税专票开户行
  • 如何根据销售额降序排序
  • 党建经费可以用来干什么
  • 水果销售公司简介
  • 最近的火车票代售点
  • 非独立核算的分公司如何报税
  • 海关增值税进项转出
  • 应付未付的职工工资属于什么会计科目
  • 用企业资本金购物违法吗
  • 支付广告费要交增值税吗
  • 借款的印花税入哪个账户
  • 什么叫二类费用
  • 买二手设备需要注意的事项
  • 一般企业可以开检测费吗
  • 酒店装修费用会计处理
  • 社会团体的费用包括哪些
  • 经营租赁方式租入分录
  • 合伙企业财产的管理和使用规定
  • 月末库存商品怎么记账
  • 收到客户付款 会计分录
  • 收到押金缴国库费怎么办
  • 对于接受捐赠的资产价值,应计入当期损益
  • windows11怎么设置锁屏密码
  • 来料加工方式中,料件和加工后
  • 高新技术企业的研发费用加计扣除
  • vue做移动端适配最佳解决方案,亲测有效
  • 股权转让所得怎么做账
  • windows 查询进程
  • php流程引擎
  • 前端页面默认字体
  • 苏门答腊岛海岸线多少
  • 个人抬头有什么用
  • PostMan接口测试(很全面的接口测试教程)
  • Pytorch深度学习实战3-5:详解计算图与自动微分机(附实例)
  • 给销售人员的返点怎么做账
  • 与下级往来账户贷方核算的内容有
  • 债券发行的分录
  • 用于职工福利的进项税账务处理
  • cms是前端还是后端
  • 织梦小说采集
  • 一般纳税人是怎么征收
  • 长期借款期末余额表示什么
  • 在建工程盘盈盘亏的账务处理
  • 不合格机器设备怎么处理
  • mysql group by实现原理
  • 企业所得税退税会计分录
  • 以前年度少记税怎么办
  • 收到存款利息属于资金周转吗
  • 事业单位公务卡额度多少
  • 转售水电费收入确认
  • 住宿费专用发票会计分录
  • 用美元账户余额怎么用
  • 处理旧固定资产税率
  • 收到增值税发票后该如何处理啊?
  • 供应商质量索赔流程
  • 应收账款平均余额公式
  • mysql的基本介绍
  • win10开机提醒
  • win8修改锁屏壁纸
  • 图文详解地理图册电子版
  • bootstrap应用
  • jQuery实现Tab选项卡切换效果简单演示
  • 用css制作网页的步骤
  • jquery滚动条滚动到指定位置
  • python程序员必读书籍
  • js布局与css布局
  • 七牛云和ucloud
  • Android ORM之GreenDao学习
  • 自然人申报密码丢失如何找回
  • 江苏省税务局官网电话
  • 十大上海企业纳税排行榜
  • 个体诊所可以申请医保报销吗
  • 扣缴个人所得税怎么计算
  • 济南市市中区二手房
  • 混凝土税率是多少2021
  • 所得税汇算清缴退税税务局要来查账
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设