从头开始学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 (七)——函数的更多相关文章
- 从头开始学JavaScript (十二)——Array类型
		原文:从头开始学JavaScript (十二)--Array类型 一.数组的创建 注:ECMAscript数组的每一项都可以保存任何类型的数据 1.1Array构造函数 var colors = ne ... 
- 从头开始学JavaScript (十一)——Object类型
		原文:从头开始学JavaScript (十一)--Object类型 一.object类型 一个object就是一系列属性的集合,一个属性包含一个名字(属性名)和一个值(属性值). object对于在应 ... 
- 从头开始学JavaScript (十)——垃圾收集
		原文:从头开始学JavaScript (十)--垃圾收集 一.垃圾收集 1.1javascript垃圾收集机制: 自动垃圾收集,执行环境会负责管理代码执行过程中的使用的内存.而在C和C++之类的语言中 ... 
- 从头开始学JavaScript (九)——执行环境和作用域
		原文:从头开始学JavaScript (九)--执行环境和作用域 一.执行环境:定义了变量或者函数有权访问的其他数据,决定了它们各自的行为.每个执行环境都有与之关联的变量对象. 变量对象:保存着环境中 ... 
- 从头开始学JavaScript (八)——变量
		原文:从头开始学JavaScript (八)--变量 一.变量分类: 基本类型值:null.undefined.number.string.Boolean: 引用类型值:保存在内存中的对象,如:Obj ... 
- 从头开始学JavaScript (六)——语句
		原文:从头开始学JavaScript (六)--语句 一.条件分支语句:if 基本格式: if (<表达式1>){ <语句组1>}else if (<表达式2> ... 
- 从头开始学JavaScript (五)——操作符(二)
		原文:从头开始学JavaScript (五)--操作符(二) 一.乘性操作符 1.乘法:* 乘法操作符的一些特殊规则: 如果操作数都是数值,按照常规的乘法计算,如果乘积超过了ECMAscri ... 
- 从头开始学JavaScript (四)——操作符
		原文:从头开始学JavaScript (四)--操作符 一.一元操作符 1.自增自减操作符:分为前置型和后置型: 前置型:++a;--a; 后置型:a++;a--; 例: <script typ ... 
- 从头开始学JavaScript (二)——变量及其作用域
		原文:从头开始学JavaScript (二)--变量及其作用域 一.变量 ECMAscript变量是松散型变量,所谓松散型变量,就是变量名称可以保存任何类型的数据,每个变量仅仅是一个用于保存值的占位符 ... 
随机推荐
- UVA - 12338 Anti-Rhyme Pairs (哈希)
			Description D Anti-Rhyme Pairs Input: Standard Input Output: Standard Output Often two words that rh ... 
- [Ruby]How to create singleton class ?
			Singleton is one design pattern in the software engineering. Ruby has its own special feature to dec ... 
- pragma once与#ifndef的作用有什么区别
			#pragma once 这是一个比较常用的指令,只要在头文件的最开始加入这条指令就能够保证头文件被编译一次 #pragma once用来防止某个头文件被多次include,#ifndef,#defi ... 
- Statement和PreparedStatement的区别; 什么是SQL注入,怎么防止SQL注入? (转)
			问题一:Statement和PreparedStatement的区别 先来说说,什么是java中的Statement:Statement是java执行数据库操作的一个重要方法,用于在已经建立数据库连接 ... 
- 日积月累:weightSum和layout_weight属性合用
			解说一:weightSum和layout_weight属性合用 android:weightSum属性:定义weight总和的最大值. 假设为指定该值,全部子视图的layout_weight属性的累加 ... 
- MongoDB(三)——CRUD
			MongoDB作为非关系型数据库.还是传统数据库的增删改查有很大的差别的.这里仅仅是将知识点进行了一下提纲挈领,实际用的时候.我们百度一下具体使用方法就可以. 先看大的几个方面: 一.对于里边的插入和 ... 
- FreeBSD包管理
			FreeBSD软件没有安装Ubuntu的apt-get.它也不是Gentoo的portage.有三种方式: package ports 自主进行源代码编译安装 这里简介前两种. FreeBSD 6.0 ... 
- apache tomcat 集群! (转)
			公司需要一个内部测试局域网, 要求可以支持3000并发访问!以前也没做过服务器这方面.临时抱佛脚,查看了N多文档,他人经验,布置好之后,又遇到了N多问题,功夫不负有心人.终于还是完成了要求!观他人的布 ... 
- Nova创建虚拟机的底层代码分析
			作为个人学习笔记分享.有不论什么问题欢迎交流! 在openstack中创建虚拟机的底层实现是nova使用了libvirt,代码在nova/virt/libvirt/driver.py. #image_ ... 
- C# 判断文件的真实格式
			为了防止图片木马,通过后缀判断文件的格式是不准确的.可以通过这种方式进行判断. static void Main(string[] args) { string path = @"C:\Us ... 
