位置: 编程技术 - 正文

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)

  • 所得税费用科目属于什么科目
  • 没有发票就不能入账吗
  • 小规模 季度
  • 全额计提坏账准备后,多久核销应收账款
  • 赠品不开票如何做账
  • 物业公司财务制度及核算方法
  • 做账时计提费用不含税怎么取整
  • 房租违约金收入怎么做账
  • 土地以租代卖,违法吗
  • 工厂筹建期间购房合法吗
  • 城市维护建设税属于什么科目
  • 备用金现金日记账表格
  • 工业企业外购存货的入账价值一般包括增值税吗
  • 超市预付卡销售开票管理规定最新
  • 财产租赁合同印花税优惠政策
  • 当月发票开错了已经红冲怎么做分录?
  • 公司购买的五金工具报销怎么做
  • 提前预支费用怎么写
  • 部分预收账款会计科目
  • 增值税电子发票怎么开具流程
  • 开具增值税发票销货清单的最新规定是什么
  • 企业所得税一般是多少
  • 内账的成本结转含税还是不含税?
  • 关于保安员服务内容主要包括
  • 科技型中小企业怎么认定
  • 哪些进项税不能加计抵减
  • 过路费发票可以抵扣增值税吗
  • 股票现金分红
  • 制造费用计入期间费用吗
  • 出口退税和增值税抵扣一样吗
  • 税负率一般控制在多少合适
  • 成本加成定价法包括()
  • 非流动资产基金是什么意思
  • 广告制作包括印花吗
  • 政府发放奖励金如何入账
  • ocxdll.exe - ocxdll是什么进程 有什么用
  • 板栗怎样保存1年不坏
  • phpmailer 使用
  • 百慕大玛丽号
  • lvs安装配置
  • 个人往来款如何转为公司股权
  • 微信小程序开发一个多少钱
  • php_curl.dll
  • 上年度会计凭证怎么填写
  • 出资比例不等于100%
  • MySQL的LEFT JOIN表连接的进阶学习教程
  • 印花税的申报表怎么打印
  • sql cell函数
  • 什么是认缴出资金额
  • 营业执照变更法人需要本人去吗
  • 应付账款长时间不付款怎么处理
  • 汇兑损益财务费用借方
  • 增值税发票丢失罚款多少
  • 如何理解会计的本质
  • 商标注册费计入哪个科目
  • 销售 返利
  • 电子发票是否使用
  • 研发支出费用化支出结转到哪个科目
  • win8pe无法识别硬盘
  • Windows Server 2003服务器安全设置
  • 建立iis
  • PureVoice.exe - PureVoice是什么进程 有什么用
  • win1021年更新
  • centos如何查看服务进程
  • WZor曝光Win10专业版升级教育版的密钥 无法激活
  • javascript运用
  • javascript获取数据类型
  • android 一个activity多个layout
  • linux rpm -i
  • perl 文本文件处理
  • js数组操作函数
  • nodejs oom
  • nodejs word
  • emulator: ERROR: no search paths found in this AVD's configuration. Weird, the AVD's config.ini file
  • unity3d最新
  • 简述bootstrap中模态框的javascript方法
  • jquery动态添加的元素怎么添加事件
  • python入门小程序编写
  • jquery mobile怎么样
  • 进出口贸易产品种类
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设