码迷,mamicode.com
首页 > Web开发 > 详细

JS匿名执行函数

时间:2016-10-04 13:50:46      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:

一、匿名函数的创建

第一种:(调用sum后可执行)

var sum=function(x,y){

return x+y;

}

第二种:(可自执行)

void function(x,y){

}(1,2);

自执行的匿名函数

    1. 什么是自执行的匿名函数?
    它是指形如这样的函数: (function {// code})();
    2. 疑问
    为什么(function {// code})();可以被执行, 而function {// code}();却会报错?
    3. 分析
    (1). 首先, 要清楚两者的区别:
    (function {// code})是表达式, function {// code}是函数声明.
    (2). 其次, js"预编译"的特点:
    js在"预编译"阶段, 会解释函数声明, 但却会忽略表式.
    (3). 当js执行到function() {//code}();时, 由于function() {//code}在"预编译"阶段已经被解释过, js会跳过function(){//code}, 试图去执行();, 故会报错;
    当js执行到(function {// code})();时, 由于(function {// code})是表达式, js会去对它求解得到返回值, 由于返回值是一 个函数, 故而遇到();时, 便会被执行.

   另外, 函数转换为表达式的方法并不一定要靠分组操作符(),我们还可以用void操作符,~操作符,!操作符……

如:

void function(x,y){
alert("fdf");
}(1,2);

!function(x,y){
alert("fdf");
}(1,2);

 

JS匿名执行函数

标签:

原文地址:http://www.cnblogs.com/littlewriter/p/5930278.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!