JS立即执行函数功能与用法分析


Posted in Javascript onJanuary 15, 2019

本文实例讲述了JS立即执行函数功能与用法。分享给大家供大家参考,具体如下:

相信大家经常会遇到下面这两种写法:

(function(){ ... })()

(function(){ ... }())

关于这样写是什么意思呢?有什么区别呢?

在此之前,我们需要了解几个概念:

函数声明函数表达式匿名函数

函数声明: function fnName() {...} ;

使用 function 关键字声明一个函数,再执行一个函数名,叫函数声明。

函数表达式: var fnName = function() { ... } ;

使用 function 关键字声明一个函数,但未给函数命名,最后将匿名函数赋予一个变量,叫函数表达式,这是最常见的函数表达式语法形式。

匿名函数: function() { ... } ;

使用 function 关键字声明一个函数,但未给函数命名,所以叫匿名函数,匿名函数属于函数表达式,匿名函数有很多作用,赋予一个变量则创建函数,赋予一个事件则成为事件处理程序或创建闭包等等。

函数声明和函数表达式不同之处在于

1、JavaScript 引擎在解析 JavaScript 代码时会“函数声明提升”当前执行环境(作用域)上的函数声明,而函数表达式必须等到 JavaScript 引擎执行到它所在行时,才会从上而下一行一行地解析函数表达式。

2、函数表达式后面可以加括号立即调用该函数,函数声明不可以,只能以 fnName() 形式调用。

知道了这些函数基本概念后,回头看看 (function(){ ... }()) (function() { ... })() 这两种立即执行函数的写法,最初我以为是一个括号包裹匿名函数,并在后面加个括号立即调用函数,当时不知道为什么要加括号,后来明白,要在函数体后面加括号就能立即调用,则这个函数必须是函数表达式,不能是函数声明。

(function(a) {
 console.log(a); //使用()运算符,打印出123
})(123);
(function(a) {
 console.log(a); //使用()运算符,打印出1234
}(1234));
!function(a) {
 console.log(a); //使用!运算符,打印出12345
}(12345);
+function(a) {
 console.log(a); //使用+运算符,打印出123456
}(123456);
-function(a) {
 console.log(a); //使用-运算符,打印出1234567
}(1234567);
var fn = function(a) {
 console.log(a); //使用=运算符,打印出12345678
}(12345678);

可以看到输出结果,在 function 前面加 ! 、+ 、- 甚至是逗号等都可以起到函数定以后立即执行的效果,而 () 、! 、+ 、- 、= 等运算符,都将函数声明转换成函数表达式,消除了 javascript 引擎识别函数表达式和函数声明的歧义,告诉 javascript 引擎这是一个函数表达式,不是函数声明,可以在后面加括号,并立即执行函数的代码。

加括号是最安全的做法,因为 ! 、+ 、- 等运算符还会和函数的返回值进行运算,有时造成不必要的麻烦。

不过这样的写法有什么用呢?

javascript 中没有私有作用域的概念,如果在多人开发的项目上,你在全局或局部作用域中声明了一些变量,可能会被其他人不小心用同名的变量给覆盖掉,根据 javascript 函数作用域链的特性,可以使用这种技术可以模仿一个私有作用域,用匿名函数作为一个“容器”,“容器”内部可以访问外部的变量,而外部环境不能访问“容器”内部的变量,所以 (function(){ ... })() 内部定义的变量不会和外部的变量发生冲突,俗称“匿名包裹器”或“命名空间”。

jQuery 使用的就是这种方法,将 jQuery 代码包裹在 (function(window,undefined){ ...jquery代码...})(window) 中,在全局作用域中调用 jQuery 代码时,可以达到保护 jQuery 内部变量的作用。

更多关于JavaScript相关内容可查看本站专题:《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
10款新鲜出炉的 jQuery 插件(Ajax 插件,有幻灯片、图片画廊、菜单等)
Jun 08 Javascript
基于jQuery的烟花效果(运动相关)点击屏幕出烟花
Jun 14 Javascript
jquery通过load获取文件的内容并跳到锚点的方法
Jan 29 Javascript
在JS方法中返回多个值的方法汇总
May 20 Javascript
JQuery用户名校验的具体实现
Mar 18 Javascript
jQuery原理系列-常用Dom操作详解
Jun 07 Javascript
大型JavaScript应用程序架构设计模式
Jun 29 Javascript
Angular2 (RC5) 路由与导航详解
Sep 21 Javascript
Vue.js实现一个todo-list的上移下移删除功能
Jun 26 Javascript
JS闭包经典实例详解
Dec 20 Javascript
layui多图上传实现删除功能的例子
Sep 23 Javascript
在Angular中实现一个级联效果的下拉框的示例代码
May 20 Javascript
vue-cli 目录结构详细讲解总结
Jan 15 #Javascript
webpack file-loader和url-loader的区别
Jan 15 #Javascript
jQuery+vue.js实现的多选下拉列表功能示例
Jan 15 #jQuery
Element输入框带历史查询记录的实现示例
Jan 15 #Javascript
微信小程序实现多选删除列表数据功能示例
Jan 15 #Javascript
element-ui带输入建议的input框踩坑(输入建议空白以及会闪出上一次的输入建议问题)
Jan 15 #Javascript
微信小程序外卖选购页实现切换分类与数量加减功能案例
Jan 15 #Javascript
You might like
给海燕B411配件机起死回生配上件
2021/03/02 无线电
兼容PHP5的PHP目录管理函数库
2008/07/10 PHP
php获取文件夹路径内的图片以及分页显示示例
2014/03/11 PHP
yii中widget的用法
2014/12/03 PHP
Laravel 5框架学习之模型、控制器、视图基础流程
2015/04/08 PHP
Zend Framework教程之配置文件application.ini解析
2016/03/10 PHP
删除PHP数组中头部、尾部、任意元素的实现代码
2017/04/10 PHP
图片格式的JavaScript和CSS速查手册
2007/08/20 Javascript
在javascript将NodeList作为Array数组处理的方法
2010/07/09 Javascript
JavaScript Date对象 日期获取函数
2010/12/19 Javascript
100个不能错过的实用JS自定义函数
2014/03/05 Javascript
一个简单的动态加载js和css的jquery代码
2014/09/01 Javascript
js格式化输入框内金额、银行卡号
2016/02/01 Javascript
JavaScript中的splice方法用法详解
2016/07/20 Javascript
js的OOP继承实现(必看篇)
2017/02/18 Javascript
JS实现针对给定时间的倒计时功能示例
2017/04/11 Javascript
JavaScript数组去重的多种方法(四种)
2017/09/19 Javascript
ng-repeat指令在迭代对象时的去重方法
2018/10/02 Javascript
js实现每日签到功能
2018/11/29 Javascript
Nodejs监控事件循环异常示例详解
2019/09/22 NodeJs
ant design 日期格式化的实现
2020/10/27 Javascript
Python类方法__init__和__del__构造、析构过程分析
2015/03/06 Python
Python实现爬虫设置代理IP和伪装成浏览器的方法分享
2018/05/07 Python
python将list转为matrix的方法
2018/12/12 Python
安装python及pycharm的教程图解
2019/10/10 Python
python的scipy.stats模块中正态分布常用函数总结
2021/02/19 Python
html5的localstorage详解
2017/05/09 HTML / CSS
英国女士和男士时尚服装网上购物:Top Labels Online
2018/03/25 全球购物
高中生自我评语大全
2014/01/19 职场文书
制药工程专业职业生涯规划范文
2014/03/10 职场文书
艺术学院毕业生求职信
2014/07/09 职场文书
质监局领导班子对照检查材料思想汇报
2014/09/27 职场文书
党员个人整改方案及措施
2014/10/25 职场文书
房屋买卖协议样本
2014/11/16 职场文书
Python一行代码实现自动发邮件功能
2021/05/30 Python
vue3 自定义图片放大器效果的示例代码
2022/07/23 Vue.js