`
王之子
  • 浏览: 110340 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

JavaScript 匿名函数的作用

阅读更多

    在 WEB 开发中有时候有这样的需求:用 JavaScript 技术,我们要在一个函数 fun 中传递一个类型为函数的参数 b ,并且函数 b 又要带参数,该怎么办呢?且看下面的例子。

 

<script>
function func(a,b) {
 alert(a);//你的业务逻辑
 b();//运行函数 b
}
var c = 5;
func(1,function(c) {
  c=c+5
  alert(c);
});
</script>​

 

   运行上面的例子可以知道,第二个 alert 打印出来的是 NaN 。及无法通过上面的方法传参。这时匿名函数就派上用场了。

 

<script>
function func(a,b) {
 alert(a);//你的业务逻辑
 b();//运行函数 b
}
var c = 5;
func(1,(function(c) {
  return function() {//返回一个匿名函数作为参数
      c=c+5
      alert(c);
  }
})(c));
</script>

 

   这时就会2个弹窗提示,第一个是1,第二个是10。也许你会感到奇怪,为什么要在匿名函数再次返回一个函数。

 

<script>
function func(a,b) {
 alert(a);//你的业务逻辑
 b();//运行函数 b
}
var c = 5;
func(1,(function(c) {
  c=c+5
  alert(c);
})(c));
</script>

 

    可以看到会有2个弹窗提示,但第一个是 10,第二个是 1 。并且用 google chrome 的开发人员工具的控制台可以看到有如下错误:

 



 

 

(function(c{

  c=c+5

  alert(c);

})(c)


   在 func 函数中,在第一个括号内,是一个匿名函数;第二个括号,表示立即执行。

 

 

关于匿名函数可以参考这里

 

 

原文链接:http://woqilin.blogspot.com/2012/10/javascript.html

个人主页: https://plus.google.com/+sherlockwang/posts

  • 大小: 2.3 KB
分享到:
评论

相关推荐

    Javascript的匿名函数

    总之,匿名函数是JavaScript中一种强大的工具,能够帮助开发者更好地组织代码、管理作用域以及实现模块化设计。然而,在使用过程中需要注意其潜在的问题,如性能开销和作用域陷阱等,以确保代码的质量和效率。通过...

    javascript 闭包、匿名函数、作用域链

    JavaScript中的闭包、匿名函数和作用域链是编程中至关重要的概念,它们是理解JavaScript运行机制的关键。在本文中,我们将深入探讨这三个概念,并通过实际示例来展示它们的运用。 首先,我们来讨论“闭包”。闭包是...

    JavaScript 匿名函数和闭包介绍

    在讨论JavaScript编程语言时,匿名函数和闭包是两个重要的概念,它们在函数式编程和模块化代码设计中扮演着核心角色。匿名函数是没有具体名称的函数,它们可以是独立的,也可以是表达式的一部分,通常用于定义临时...

    Javascript的匿名函数讲解

    总的来说,匿名函数在JavaScript编程中扮演着重要的角色,它不仅帮助开发者管理变量作用域,而且提高了代码的模块化和可维护性。在设计和实现JavaScript程序时,正确地使用匿名函数将有助于保持代码的优雅与清晰。

    匿名函数的一点知识

    综上所述,匿名函数在JavaScript中扮演着至关重要的角色,不仅可以用于创建立即执行的代码块,实现作用域隔离,还可以作为参数传递、实现回调机制,甚至用于封装私有和公共功能,提高代码的封装性和安全性。...

    深入研究JavaScript的匿名函数.doc

    JavaScript中的匿名函数是一种没有明确标识符的函数表达式,它可以在需要时被立即执行或作为其他数据结构的一部分使用。在JavaScript中,函数是第一类对象,这意味着它们可以被赋值给变量、作为参数传递和作为其他...

    javascript匿名函数应用示例介绍

    javascript匿名函数,就是说个函数没有名字,下面先列出测试代码 代码如下: /* * 一般常见函数是这样 */ function debug(data) { console.log(data); } 但有的函数,它却偏偏写成了这样 代码如下: (function(x, y) {...

    JavaScript程序设计课件:匿名函数.pptx

    匿名函数 5.5 匿名函数 函数表达式 概念:所谓函数表达式指的是将声明的函数赋值给一个变量,通过变量完成函数的调用和参数的传递,它也是JavaScript中另一种实现自定义函数的方式。 5.5 匿名函数 函数表达式 var fn...

    JavaScript中匿名函数的用法及优缺点详解_.docx

    总的来说,匿名函数在JavaScript中起着至关重要的作用,它们提供了一种简洁且灵活的方式来处理函数,尤其是在需要创建临时或一次性使用的函数时。然而,使用匿名函数时需谨慎,确保代码的可读性和性能。在实际开发中...

    javascript匿名函数实例分析

    以上就是JavaScript匿名函数实例分析的知识点。通过实例的讲解,我们了解了匿名函数的定义、用法及注意事项。掌握这些概念对编写高质量的JavaScript代码非常重要。对于希望深入学习JavaScript的开发者来说,理解和...

    JS匿名函数、闭包

    JavaScript本身没有块级作用域的概念,但是通过创建并立即执行的匿名函数可以模拟出这一特性: ```javascript (function() { var secret = 'hidden'; console.log(secret); // hidden })(); console.log(secret)...

    JavaScript中匿名函数的用法及优缺点详解_.pdf

    总之,匿名函数是JavaScript中一个强大而灵活的工具,尤其适用于处理局部作用域、模块化和函数式编程。然而,正确使用它们是至关重要的,以确保代码的可维护性和性能。在实践中,开发者应根据项目需求平衡匿名函数的...

    javascript_函数大全

    这种特性使得函数能够成为高阶函数的基础,支持诸如匿名函数、回调函数、自调用函数等高级概念。 #### 高级函数概念 - **匿名函数**:没有名称的函数,常用于立即执行的表达式或作为参数传递。 - **回调函数**:...

    (转载)JavaScript中匿名函数,函数直接量和闭包.docx

    在JavaScript中,匿名函数、函数直接量和闭包是三种非常重要的概念,它们在编程实践中有着广泛的应用。让我们逐一深入探讨这些概念。 1. **匿名函数**: 匿名函数是指没有名字的函数,通常作为表达式的一部分存在...

    JavaScript: 函数与作用域深入解析及应用场景

    接着讨论了 JavaScript 中的全局作用域、局部作用域、块级作用域和函数作用域,特别是闭包的概念。随后,文章探讨了函数的高级用法,如递归函数、高阶函数和立即执行函数表达式(IIFE)。最后,通过实际应用示例,如...

    javascript笔记之匿名函数和闭包.docx

    总的来说,JavaScript中的匿名函数和闭包是强大的工具,它们可以帮助我们创建私有变量、实现模块化和数据封装,以及在异步编程中起到重要作用。理解并熟练运用这些概念对于任何JavaScript开发者来说都是至关重要的。

    javascript笔记之匿名函数和闭包

    JavaScript中的匿名函数和闭包是两个非常重要的概念,它们在函数式编程和模块化开发中起着关键作用。 首先,让我们来理解匿名函数。匿名函数,顾名思义,是没有名称的函数。在JavaScript中,我们可以直接定义一个不...

Global site tag (gtag.js) - Google Analytics