位置: 编程技术 - 正文

JavaScript中立即执行函数实例详解(js立即执行函数几种写法)

编辑:rootadmin

推荐整理分享JavaScript中立即执行函数实例详解(js立即执行函数几种写法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js setinterval立即执行,JavaScript中立即执行函数的作用,js立即执行函数几种写法,js立即执行函数和闭包,js setinterval立即执行,JavaScript中立即执行函数的作用,JavaScript中立即执行函数的作用,javascript立即执行函数,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

js立即执行函数可以让你的函数在创建后立即执行,js立即执行函数模式是一种语法,可以让你的函数在定义后立即被执行,这种模式本质上就是函数表达式(命名的或者匿名的),在创建后立即执行。

( function(){…} )()和( function (){…} () )是两种javascript立即执行函数的常见写法,最初我以为是一个括号包裹匿名函数,再在后面加个括号调用函数,最后达到函数定义后立即执行的目的,后来发现加括号的原因并非如此。

下面话不多说了,来一起看看详细的介绍吧。

通常我们声明一个函数有以下几种方式:

如果你看过一些自定义控件的话你会发现他们大多数都是沿用这种写法:

这是我们常说的立即执行函数(IIFE),顾名思义,也就是说这个函数是立即执行函数体的,不需要你额外去主动的去调用,一般情况下我们只对匿名函数使用IIFE,这么做有两个目的:

一是不必为函数命名,避免了污染全局变量

二是IIFE内部形成了一个单独的作用域,可以封装一些外部无法读取的私有变量。

如果看到这两句话无法理解,那么先从IIFE的运行原理说起。

因为IIFE通常用于匿名函数,这里就用简单的匿名函数作为栗子:

JavaScript中立即执行函数实例详解(js立即执行函数几种写法)

我们发现这里f只是这个匿名函数的一个引用变量,那么既然f()能够调用这个函数,我把f替换成函数本身可以么:

运行之后得到如下结果:

产生这个错误的原因是,Javascript引擎看到function关键字之后,认为后面跟的是函数声明语句,不应该以圆括号结尾。解决方法就是让引擎知道,圆括号前面的部分不是函数定义语句,而是一个表达式,可以对此进行运算,这里区分一下函数声明和函数表达式:

1、函数声明(即我们通常使用function x(){}来声明一个函数)

2、函数表达式(类似以这种的形式)

小学我们就学过用()括起来的表达式会先执行,就像下面这样:

其实在javascript中小括号也有相似的作用,Javascript引擎看到function关键字会认为是函数声明语句,那么如果Javascript引擎优先看到小括号会怎么样:

函数成功执行了:

这种情况下Javascript引擎就会认为这是一个表达式,而不是函数声明,当然要让Javascript引擎认为这是一个表达式的方法还有很多:

回到前面的问题,为什么说IIFE这种形式避免了污染全局变量,如果你见过别人写的jquery插件,里面通常会有类似这样的代码:

这里的jquery其实是该匿名函数的参数,联想一下我们调用匿名函数时候是用f()那么匿名带参数的就是f(args)对吧,这里把jquery作为参数传入该函数,那么在函数内部使用形参$的时候就不会影响到外部环境,因为有些插件也会用到$这个限定符,你在这个函数内部可以随意折腾。

以上,在此过程中参考了以下两篇文章:

javascript立即执行某个函数:插件中function(){}()再思考

JavaScript中的立即执行函数

总结

标签: js立即执行函数几种写法

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

上一篇:javascript+jQuery实现360开机时间显示效果(jquery())

下一篇:详解使用React全家桶搭建一个后台管理系统(react用什么ui)

  • 研发机构采购设计方案
  • 增值税可以在企业所得税时扣除吗
  • 公立医院事业单位录用是编制吗
  • 付款后发票可以抵扣吗
  • 广告公司个体户自己可以开发票
  • 动物园的动物算野生动物吗
  • 金税盘处于报税期不能开票是什么意思
  • 应付账款以前年度挂错
  • 与成本直接相关的工资怎么会计处理?
  • 小规模纳税人开具1%增值税专用发票可以抵扣吗
  • 股东往来款怎么处理
  • 企业财务会计制度范本
  • 预付的账款属于
  • 不付供应商尾款了怎么清账
  • 环境保护税的计算例题
  • 注册资本印花税税目是什么
  • 消耗性生物资产的账务处理
  • 付款方付款的发票税金能入账吗?
  • 向人力资源公司辞职怎么说
  • 利息保障倍数如何计算
  • windows10自带桌面时钟
  • 进程调度算法例题分析
  • 销售折让负数会计分录
  • apcu php
  • php files
  • 其他业务支出属于什么会计科目
  • vue数据更新会触发什么生命周期
  • 所得税返还计入什么科目
  • smarty怎么用
  • Aerial view of Chapel Bridge over the river Reuss in Lucerne, Switzerland (© Neleman Initiative/Gallery Stock)
  • 代扣代缴增值税账务处理
  • gcn时间序列
  • crontab命令用法
  • 详解Yii2 rules 的验证规则
  • 运营费的税率
  • 美容店销售收入预测表12个月表格
  • 跨年发票一般分为哪几类
  • 税务申报核定销售额在哪填写
  • 价外费用企业所得税
  • 工程施工二级设哪些明细
  • sqlserver监视器
  • 财务软件期末处理
  • 缴纳以前年度房租的税
  • 营业总收入包含什么
  • 股东权益是资产吗
  • 进项税额转出分录怎么写,附加的原始凭证是什么
  • 教育费附加和地方教育费附加都要交吗
  • 减免所得税需要交税吗
  • 收到税务局退回的增值税税款怎么做账
  • 车间杂工工资如何结算
  • 电子银行承兑汇票
  • 残疾人就业保障金怎么申报
  • 增值税附加税有哪些
  • 完工结转的会计分录
  • 小规模纳税人租赁不动产税率
  • 应付工资的计算公式用友
  • 期末留抵税额可以冲减欠税吗
  • 施工方怎么开发票
  • 公司刚成立如何做账
  • 工业投资范围是什么
  • php连接mysql数据库的几种方式及区别
  • win7系统安装完后启动不了
  • 滑动关闭电脑功能按键在哪找
  • 0x80070718配额不足
  • mac 应用
  • linux操作系统版本有哪些
  • 微信付费使用是真的吗
  • newdot.exe - newdot是什么进程 有什么用
  • centos ssh升级
  • win10系统怎么设置开机启动项
  • 摄像头挡住了
  • 日亚海淘官网
  • 快速掌握一个方法
  • bat注销命令
  • javascript概述及作用
  • 基于jQuery和Bootstrap的设计报告的参考文献
  • javascript 做网页
  • php jquery教程
  • 企业所得税税率10%
  • 建设工程造价咨询合同需要交印花税吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设