首页 > Web开发 > 详细

js学习笔记34----自执行函数

时间:2018-06-03 00:39:49      阅读:286      评论:0      收藏:0      [点我收藏+]

自执行函数的写法通常如下:

方式1:

(function(){
    ***
    写事件处理代码
    ***
}())

 

方式2:

(function(){
    ***
    写事件处理代码
    ***
})()

 

方式3:

!(function(){
    ***
    写事件处理代码
    ***
})()

在function前面加!、+、-、=都可以将函数声明转化为函数表达式,消除了js引擎识别函数声明和函数表达式的歧义,加()是最安全的方法,免得其他的和函数返回值进行运算。

 

自执行函数传参时,参数赋值直接在后面的括号里面:

(function(arg){
    console.log(arg);  //输出1
}(1))

 

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

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

 

js学习笔记34----自执行函数

原文:https://www.cnblogs.com/sese/p/9127567.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!