function-函数表达式执行的问题

问题描述

函数表达式执行的问题

var $aaa = (function() { return function(a){ alert(a); } } )(); $aaa(10); 这样的一段代码在执行时,如果在第一个分号前的括号中写上10,为什么不会弹出10,而$aaa(10);这样写会弹出10呢??

解决方案

 var $aaa = (
    function() {
        return function(a)
        {
            alert(a);
        }
    }
)()(10);

解决方案二:

执行的匿名函数返回了函数,赋值给$aaa变量,只是申明了函数,并没有执行。。还没搞清楚?

时间: 2024-10-31 04:14:27

function-函数表达式执行的问题的相关文章

全面了解函数声明与函数表达式、变量提升_javascript技巧

函数的声明方式 在定义一个函数的时候通常有两种声明方式: foo(){}; // 函数声明 var foo = function(){}; // 函数表达式 不同之处 1.函数表达式后面加括号可以直接执行 2.函数声明会提前预解析 预解析 让我们先看一个例子: foo(); // 函数声明 foo_later(); // foo_later is not a function function foo(){ console.log('函数声明'); } var foo_later = funct

JavaScript中的立即执行函数表达式介绍

 这篇文章主要介绍了JavaScript中的立即执行函数表达式介绍,本文着重讲解了什么是立即调用函数表达式,需要的朋友可以参考下     我们习惯看到这样的匿名函数 代码如下: (function(){ console.log("test"); })(); 之前一直叫的是自执行的匿名函数(self-executing anonymous function)   发现原来还有一种叫法是: 立即调用函数表达式 (IIFE,Immediately-Invoked Function Expre

《JavaScript应用程序设计》一一2.4 立即执行函数表达式

2.4 立即执行函数表达式 在JavaScript中,我们可以在函数声明后立即将其执行,这个技术曾在社区中被称为"自执行匿名函数",不过冠以这个名称让人们觉得函数能够被递归调用,显然有点不太妥.Ben Alman曾发表了一篇名为"自执行函数表达式"(IIFE)的博文(http://bit.ly/i-ife/),相比之下,人们觉得缩写IIFE显得更为有趣且清晰易懂,现在IEIF一词已经在JavaScript社区中广为使用.IIFE所创建出的临时作用域常常用来作模块封装

JavaScript中的立即执行函数表达式介绍_javascript技巧

我们习惯看到这样的匿名函数 复制代码 代码如下: (function(){     console.log("test"); })(); 之前一直叫的是自执行的匿名函数(self-executing anonymous function) 发现原来还有一种叫法是: 立即调用函数表达式 (IIFE,Immediately-Invoked Function Expression) 立即调用函数表达式 相比于自执行匿名函数,立即调用函数表达式的意思来得更明确一些. 自执行函数有下面的这一些例

函数声明和函数表达式——函数声明的声明提前

定义函数的方法 定义函数的方法主要有三种:     函数声明(Function Declaration)     函数表达式Function Expression)     new Function构造函数 其中,经常使用的是函数声明和函数表达式的函数定义方法,这两种方法有着很微妙的区别和联系,而且这两种方法的使用也容易混淆,所以这篇文章主要总结下这两种函数定义方法的相关知识点,当然本文的主题依然是关于函数提前的. 函数声明的典型格式: function functionName(arg1, a

JS创建函数:函数声明和函数表达式

文章简介:JavaScript 中需要创建函数的话,有两种方法:函数声明.函数表达式. JavaScript 中需要创建函数的话,有两种方法:函数声明.函数表达式,各自写法如下: // 方法一:函数声明function foo() {} // 方法二:函数表达式var foo = function () {}; 另外还有一种自执行函数表达式,主要用于创建一个新的作用域,在此作用域内声明的变量 不会和其它作用域内的变量冲突或混淆,大多是以匿名函数方式存在,且立即自动执行: (function ()

Javascript中函数声明与函数表达式的区别

Js中的函数声明是指下面的形式: function functionName(){ } 这样的方式来声明一个函数,而函数表达式则是类似表达式那样来声明一个函数,如: var functionName = function(){ } 可能很多朋友在看到这两一种写法时会产生疑惑,这两种写法差不多,在应用中貌似也都是可行的,那他们有什么差别呢? 事实上,js的解析器对函数声明与函数表达式并不是一视同仁地对待的.对于函数声明,js解析器会优先读取,确保在所有代码执行之前声明已经被解析,而函数表达式,如同

JavaScript Function函数类型介绍

 // 在JS中,Function(函数)类型实际上是对象;每个函数都是Function类型的实例;而且都与其他引用类型一样具有属性和方法; // 由于函数是对象,因此函数名实际上也是一个指向函数对象的指针; 一 函数的声明方式 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 1.函数声明方式 function box(num1,num2){ return num1+num2; }   2.函数表达式定义函数 var box = function(num1,num2){

JavaScript中的函数声明和函数表达式区别浅析

 这篇文章主要介绍了JavaScript中的函数声明和函数表达式区别浅析,本文总结的浅显易懂,非常好的一篇技术文章,需要的朋友可以参考下     记得在面试腾讯实习生的时候,面试官问了我这样一道问题. 代码如下: //下述两种声明方式有什么不同 function foo(){}; var bar = function foo(){};   当初只知道两种声明方式一个是函数声明一个是函数表达式,具体有什么不同没能说得很好.最近正好看到这方面的书籍,就想好好总结一番. 在ECMAScript中,有两