创建函数

  创建函数的方式有两种:1、函数声明,2、函数表达式

  函数声明的语法为

functionName();  //不会报错,函数声明提升
function functionName(arg0,arg1,arg2) {
//do somethings;
}
alert(functionName.name);  //输出 functionName

  也可以采用函数表达式创建函数

functionName();  //会报错,此时 functionName 仅仅是 var functionName,其值为 undefined;
var functionName = function(arg0,arg1,arg2) {
//do somethings;
}
alert(functionName.name);  //输出 ""

  


  递归

  当一个函数可以通过名字调用自身,说明该函数为 递归函数.

  

function functionName() {
// do somethings;
return functionName();
} var another = functionName;
functionName = null; another(); //报错, 因为找不到 functionName(); function functionName() {
// do somethings;
return arguments.callee(); //指向该函数的指针
} var another = functionName;
functionName = null; another();  //不报错.

  


  闭包

  了解闭包,首先了解函数的作用域。

  函数作用域里的变量,会一级级的向上查找变量,直到找到为止,找不到则报错.

var a = 1;
function getA(){
alert(a);  //当在当前作用域找不到变量时,会去父作用域查找该变量,直到找到为止,如果找不到,则报错.
}
getA(); //1;

  但是,函数作用域外的变量,则访问不到函数作用域里的变量。

function setA(){
var a = 1;
}
setA();
alert(a); //报错.因为变量 a 不能访问到 setA 里的变量,且外部也没有 变量a

  创建一个闭包函数,来访问函数里的值。

var a = 5;
function func(){
  var a = 1;
  return {
    "get":function(){
      alert(a);
    },
    "set":function(num){
      a=num;
    },
    "getthis":function(){
      alert(this.a);
    }
  }
} var a = func();  //闭包
a.get();  //输出 1;
a.set(2);
a.get();  //输出 2; var b = func();  //闭包
b.get();  //输出 1;
a.set(3);
b.get();  //输出 1;
a.get();  //输出 3;

  由上个例子可见,闭包会造成内存占用比以前更多。因此要谨慎使用闭包。


 模仿块级作用域

  由于 JavaScript 没有块级作用域,会导致有些时候会出差错,得不到我们想要的结果。

function func() {
  var i = 5;
for (var i =0;i<10;i++) {
//alert(i);
}
alert(i); //输出10; 并不是我们想要的10;
}

  因此 可以利用 立刻执行的匿名函数,来模拟块级作用域。

function func() {
var i = 5;
(function(){
for (var i = 1;i < 10;i++) {
//alert(i);
}
}());
alert(i); //输出 5
}

  


  

JavaScript Function(函数表达式)的更多相关文章

  1. javascript:function 函数声明和函数表达式 详解

    函数声明(缩写为FD)是这样一种函数: 有一个特定的名称 在源码中的位置:要么处于程序级(Program level),要么处于其它函数的主体(FunctionBody)中 在进入上下文阶段创建 影响 ...

  2. JavaScript function函数种类(转)

    转自:http://www.cnblogs.com/polk6/p/3284839.html JavaScript function函数种类 本篇主要介绍普通函数.匿名函数.闭包函数 目录 1. 普通 ...

  3. JavaScript function函数种类介绍

    JavaScript function函数种类介绍 本篇主要介绍普通函数.匿名函数.闭包函数 1.普通函数介绍 1.1 示例 ? 1 2 3 function ShowName(name) {     ...

  4. JavaScript Function 函数深入总结

    整理了JavaScript中函数Function的各种,感觉函数就是一大对象啊,各种知识点都能牵扯进来,不单单是 Function 这个本身原生的引用类型的各种用法,还包含执行环境,作用域,闭包,上下 ...

  5. 谈谈javascript的函数表达式及其应用

    我们都知道定义函数的方式有两种,一种是函数声明,另外一种就是函数表达式. 函数声明 语法为:function关键字后跟函数名.例如: function functionName(arg0) { //函 ...

  6. 【JavaScript】函数表达式

    一.前言        接着上一篇的内容,继续学习JavaScript. 二.内容       函数的声明 function functionName(arg0,arg1,arg2){ //函数体 } ...

  7. 浅谈JavaScript的函数表达式(闭包)

    前文已经简单的介绍了函数的闭包.函数的闭包就是有权访问另一个函数作用域的函数,也就是函数内部又定义了一个函数. var Super=function(num){ var count=num; retu ...

  8. JavaScript高级 函数表达式 《JavaScript高级程序设计(第三版)》

    函数表达式的特征 使用函数实现递归 使用闭包定义私有变量 前面我们说到定义函数有两种方式:函数声明.函数表达式. 两者的区别在于函数声明提升,前者在执行之前的上下文环境中直接被赋值,而后者不会. 一. ...

  9. 浅谈JavaScript的函数表达式(递归)

    递归函数,在前面的博客中已经简单的介绍了.递归函数是一个通过函数名称在函数内部调用自身的函数.如下: function fac(num){ if(num<1){ return 1; } else ...

随机推荐

  1. linux命令:head

    1.命令介绍: head用来显示文件的开头的一部分. 2.命令格式: head [选项] 文件 3.命令参数: -q 隐藏文件名 -v 显示文件名 -c<字节> 显示字节数 -n<行 ...

  2. [20150522]RPM包的管理

    RPM包的管理 RPM包的分类 RPM包可分为源码包和二进制包两类.源码包的主要优点是开源,如果有足够的能力,可以修改源代码,源码包可以自由选择所需要安装的功能,软件是编译安装,所以更加适合自己的系统 ...

  3. Json.net 忽略实体某些属性的序列化

    遇到了一个小问题有一个用户类,结构和数据库一模一样,里面包含用户密码,要向前台返回用户信息的json数据,但是不能输出密码这个字段.之前的做法是 重新又建了一个不包含这个字段的新类,然后深度复制,总感 ...

  4. mysql加单引号和不加单引号的性能比较

    刚刚我们说过了,生活中难免会有一些不如意,比如,我们用一个字符串类型的字段来作为主键,表面上,这太不如意了,然而,事实也证明这是有用的.问题也就出来了,当在查询语句中对该字段值加上单引号和不加查询耗时 ...

  5. 国外程序员整理的 C++ 资源大全(转)

    原文:http://www.csdn.net/article/2014-10-24/2822269-c 关于 C++ 框架.库和资源的一些汇总列表,由 fffaraz发起和维护. 内容包括:标准库.W ...

  6. 20151216Repeater

    Repeater 用法:.绑定数据源 Repeater1.DataSource = context.Info; Repeater1.DataBind(); .造项模版: 头模版:HeaderTempl ...

  7. java的读文件操作

    java读取文件内容,可以作如下理解: 首先获得一个文件句柄,File file = new File():file即为文件句柄.两人之间联通电话网络了,就可以开始打电话了. 通过这条线路读取甲方的信 ...

  8. flash cs6导入某些mp3不能的解决办法

    安装最新的quicktime 另外还有一个很恶心的办法,可以不用装quicktime. 1.用adobe audio打开一个没问题的mp3, 2.再打开有问题的MP3,全选,复制: 3.切换到没问题的 ...

  9. EM算法 The EM Algorithm

    (EM算法)The EM Algorithm http://www.cnblogs.com/jerrylead/archive/2011/04/06/2006936.html EM算法原理 http: ...

  10. HTML5外包

    北京动点飞扬软件 从事html5外包业务五年,是国内第一家以HTML5移动平台.手机平台项目外包业务为主的正规软件团队, 欢迎联系 QQ:372900288 电话:13911652504 我们现已发展 ...