原文:从头开始学JavaScript (七)——函数

一、return

函数在执行完return之后停止并立即退出。

return返回值;与return;

如下两个例子:

 function sum(num1, num2) {
num1= num1 + num2;
return num1;
} var result = sum(5, 10);
alert(result);//15
 function sum(num1, num2) {
num1= num1 + num2;
return;
} var result = sum(5, 10);
alert(result);//undefined;

直接return而不带任何参数的情况一般用于需要提前停止函数执行而又不需要返回值的情况。

如下:

 function counter() {
for (var count = 1; ; count++) {
console.log(count + "A");
if (count === 5) {
return;
}
console.log(count + "B");
}
console.log(count + "C");
} counter();

二、参数

ECMAscript函数参数的特点;

  • 不介意传递进来多少个参数
  • 不介意传递进来的参数的数据类型

之所以有上述两个特点,是因为ECMAscript参数在内部是用一个数组表示的。函数接收到的始终是这个数组,而不关心数组中包含哪些参数,或者是否有参数。

实际上,在函数体内可以通过arguments对象来访问这个参数数组,从而获取传递给函数的每一个参数。

例如:

function sayHi(name, message) {
alert("Hello " + name + ", " + message);
} sayHi("杨小漾", "how are you today?");

也可以写成:

function sayHi() {
alert("Hello " + arguments[0]+ ", " + arguments[1]);
} sayHi("Nicholas", "how are you today?");

因此,在javascript里面,给参数命名只是提供便利,并不是必需的。

使用arguments.length可以获知有多少个参数传递给了函数,例如:

function howManyArgs() {
alert(arguments.length);
} howManyArgs("string", 45); //
howManyArgs(); //
howManyArgs(12); //

利用这一点,可以让函数接受任意个参数并分别实现相应的功能:

     function doAdd() {
if(arguments.length == 1) {
alert(arguments[0] + 10);
} else if (arguments.length == 2) {
alert(arguments[0] + arguments[1]);
}
} doAdd(10); //
doAdd(30, 20); //

arguments还可以和命名过的参数一起用:

   function doAdd(num1, num2) {
if(arguments.length == 1) {
alert(num1 + 10);
} else if (arguments.length == 2) {
alert(arguments[0] + num2);
}
}
doAdd(10); //
doAdd(30, 20); //

arguments的值永远与对应命名参数的值保持同步:

 function doAdd(num1, num2) {
alert(arguments[0] + num2);
} doAdd(10, 20); //3
doAdd(30, 20); //
  function doAdd(num1, num2) {
arguments[1] = 10;
alert(arguments[0] + num2);
} doAdd(10, 20); //
doAdd(30, 20); //

每次执行doAdd这个函数,都会将第二个参数重写(上述例子中是将第二个参数重新赋值为10)。这是因为,arguments对象中的值会自动反映到对应的命名参数,所以修改

arguments[1],也就相当于修改了num2,不过他们俩的内存空间是独立的,值同步。
没有传递值的命名参数将会被赋予undefined,比如:
         function doAdd(num1, num2) {
alert(num2);//undefined
} doAdd(10);
arguments还有一个属性:callee,它的作用是返回正在被执行的function
例如:
         function argumentsTest (a,b) {
alert(arguments.callee);//返回函数本身
}
argumentsTest(1,2,3,4);

在使用函数递归调用时推荐使用arguments.callee代替函数名本身。

例如:

 function count(a){
if(a==1){
return 1;
}
return a + arguments.callee(--a);
} var mm = count(2);
alert(mm);
arguments.length返回的是传递给函数的参数个数,也叫实参;而arguments.callee.length返回的是什么呢?
看个例子:
 function calleeLengthDemo(arg1, arg2) {
alert("arguments.length:" +arguments.length);//
alert("arguments.callee.length:" +arguments.callee.length);// }
calleeLengthDemo(1,2,3);

由此可以看出arguments.callee.length返回的是函数定义的参数,即形参。

三、没有重载

ECMAscript函数不能实现重载,不能够定义同样的函数然后通过编译器去根据不同的参数执行不同的函数。

例如:
  function addSomeNumber(num1){
return num1 + 100;
} function addSomeNumber(num2) {
return num2 + 200;
} var result = addSomeNumber(100); //
alert(result);
 function addSomeNumber(num1){
num1+=100;
return num1 + 100;
} function addSomeNumber(num2) {
return num2 + 200;
} var result = addSomeNumber(100); //
alert(result);
只要函数名一致(上述例子中的addSomeNumber),ECMAscript就会认为是同一个东西,那么后定义的就会覆盖先定义的。
对于ECMAscript函数来说,我自己本没有参数,你给我什么参数我就接受什么样的参数。
 

从头开始学JavaScript (七)——函数的更多相关文章

  1. 从头开始学JavaScript (十二)——Array类型

    原文:从头开始学JavaScript (十二)--Array类型 一.数组的创建 注:ECMAscript数组的每一项都可以保存任何类型的数据 1.1Array构造函数 var colors = ne ...

  2. 从头开始学JavaScript (十一)——Object类型

    原文:从头开始学JavaScript (十一)--Object类型 一.object类型 一个object就是一系列属性的集合,一个属性包含一个名字(属性名)和一个值(属性值). object对于在应 ...

  3. 从头开始学JavaScript (十)——垃圾收集

    原文:从头开始学JavaScript (十)--垃圾收集 一.垃圾收集 1.1javascript垃圾收集机制: 自动垃圾收集,执行环境会负责管理代码执行过程中的使用的内存.而在C和C++之类的语言中 ...

  4. 从头开始学JavaScript (九)——执行环境和作用域

    原文:从头开始学JavaScript (九)--执行环境和作用域 一.执行环境:定义了变量或者函数有权访问的其他数据,决定了它们各自的行为.每个执行环境都有与之关联的变量对象. 变量对象:保存着环境中 ...

  5. 从头开始学JavaScript (八)——变量

    原文:从头开始学JavaScript (八)--变量 一.变量分类: 基本类型值:null.undefined.number.string.Boolean: 引用类型值:保存在内存中的对象,如:Obj ...

  6. 从头开始学JavaScript (六)——语句

    原文:从头开始学JavaScript (六)--语句 一.条件分支语句:if 基本格式: if (<表达式1>){    <语句组1>}else if (<表达式2> ...

  7. 从头开始学JavaScript (五)——操作符(二)

    原文:从头开始学JavaScript (五)--操作符(二) 一.乘性操作符 1.乘法:*      乘法操作符的一些特殊规则: 如果操作数都是数值,按照常规的乘法计算,如果乘积超过了ECMAscri ...

  8. 从头开始学JavaScript (四)——操作符

    原文:从头开始学JavaScript (四)--操作符 一.一元操作符 1.自增自减操作符:分为前置型和后置型: 前置型:++a;--a; 后置型:a++;a--; 例: <script typ ...

  9. 从头开始学JavaScript (二)——变量及其作用域

    原文:从头开始学JavaScript (二)--变量及其作用域 一.变量 ECMAscript变量是松散型变量,所谓松散型变量,就是变量名称可以保存任何类型的数据,每个变量仅仅是一个用于保存值的占位符 ...

随机推荐

  1. cocos2d-x 3.1.1 学习笔记[17] 关于这些活动功能

    供cocos2d-x通常使用的方法,我有一个好脸色.这项研究真的奖励. 向导首先,定义,实施一系列连续动作. 对于我们的行动能回调函数,我们必须申报并加以实施. void callBack(); vo ...

  2. UI设计学习路径(一个)—好酒也怕巷子深

    来源 參与米老师对项目的验收的时候.听了老师对UI的看法才注意UI这块内容.非常奇怪为什么我们总是不能注意到本该注意的问题呢?软件开发难道仅仅是功能的实现不包含界面设计吗?当然不是.问题的根源在于我们 ...

  3. [Cocos2d-x]在Cocos2d-x 3.x如何通过版本号WebSocket连接server数据的传输

    WebSocket 首先新建一个空的目录,通过npm安装nodejs-websocket: npm install nodejs-websocket 新建app.js文件: var ws = requ ...

  4. 【Espruino】NO.03 从点灯开始

    http://blog.csdn.net/qwert1213131/article/details/26819773 本文属于个人理解,能力有限,纰漏在所难免,还望指正! [小鱼有点电] 点灯程序应该 ...

  5. Flynn初步:基于Docker的PaaS台

    Flynn它是一个开源PaaS台,无论要部署的应用程序,你可以建立自己的主动性Docker容器集群的实现,能特性与组件设计大量參考了传统的PaaS平台Heroku.本文旨在从使用动机.基本对象.层次架 ...

  6. DNA和纳米(Nano)Fusion技术的发展趋势

    细观国内外有关DNA与Nano技术的报道.不得不承认存在不小的差距,并且差距有继续拉大的趋势. 在我们国内,DNA技术是作为遗产基因来对待的.引用的有关中文參考资料一般比較陈旧.缺少參考价值.在发达国 ...

  7. bsh for android : 北京

    beanshell : bjtime.bsh source("/sdcard/com.googlecode.bshforandroid/extras/bsh/android.bsh" ...

  8. nginx 提供静态内容

    Serving Static Content 提供静态内容 原文地址:http://nginx.com/resources/admin-guide/serving-static-content/ Th ...

  9. jvm在存储区域

    当区域执行的数据  JVM存储器的管理分为几个时间之后的数据区的实施:程序计数器.JavaVM栈.本地方法栈.Java堆.方法区(包括常量池的实现).   程序计数器 较小的内存空间,能够看作是当前线 ...

  10. HTML5分析实战WebSockets基本介绍

    HTML5 WebSockets规范定义了API,同意web使用页面WebSockets与远程主机协议的双向交流. 介绍WebSocket接口,并限定了全双工通信信道,通过套接字网络.HTML5 We ...