日期:2013-11-16  浏览次数:20585 次

  函数是在程序中可以反复使用的代码. 你可以将需求处理的值或对象通过参数的方式传递给函数, 然后由函数得到结果. 从另一个角度说, 函数存在目的就是为了简化编程的负担, 减小代码量和提高效率. 而一个写得好的函数, 就像一个"黑箱", 你只需懂得调用它就行了, 而不用去关怀它的具体功用是如何实现的
创建本人的函数---函数定义(Definition)
要创建一个函数, 就需求有函数的定义. 对于 Actions cript, 就没有什么前往值类型, 形参实参之类的东西好讨论了. 下面是一个简单函数的定义:
//计算矩形面积的函数
function areaOfBox(a, b) {
return a*b; //在这里前往结果
}
//测试函数
area = areaOfBox(3, 6);
trace("area="+area);
如今来分析一下函数定义的结构. function 关键字说明这是一个函数定义, 而不是一段执行代码. 其后便是函数的名称: areaOfBox. 函数名后面的括号内是函数的参数列表(也可以没有参数, 但括号是必需要有的). 紧接着的大括号内是函数的实现代码, 即 Actions cript 语句. 如果函数需求前往值, 可以使用 return 关键字加上要前往的变量名, 表达式或常量名. 在一个函数中可以有多个 return 语句, 但无论何时, 只需执行了其中的任何一个 return 后, 函数便自行终止而不会继续执行下去. 如果没有 return 语句, 则在函数尾最后一个语句执行后结束.
由于 Actions cript 的特殊性, 函数的参数定义并不要求参数类型的声明, 即可以不指定参数类型. 这省去了很多麻烦, 也带来了一些问题. 虽然把上例中倒数第二行改为 area = areaOfBox("3", 6); 也同样可以得到 18 的结果, 但是这对程序的稳定性非常不利(假如函数里面用到了 a+b 的话, 就会变成字符串的连接运算, 结果自然会出错). 所以, 有时候在函数中类型检查是不可少的.
在函数体中参变量用来代表要操作的对象. 你在函数中对参变量的操作, 就是对传递给函数的参数的操作. 上例中的 a*b 在你调用函数时会被转化为参数的实际值 3*6 处理.

--------------------------------------------------------------------------------
函数还有一种创建方法, 叫做函数显式声明(function literal, 不是通过正式的函数声明而是在一个表达式内通过未命名的函数来进行声明):
areaOfBox = function(a,b) {return a*b;};
trace("area="+areaOfBox(2,3));
这种方式的声明经常用在对象的方法或是函数库的函数声明中.
在 Flash MX 的协助中函数定义部分关于这种声明的范例代码有误, 请留意.

--------------------------------------------------------------------------------
上面是有前往值的函数, 在函数尾使用了 return 关键字来前往结果. 函数也可以不前往任何值. 如下例:
//无前往值的函数
function areaOfBox(a, b) {
_root.area = a*b;
}
//测试函数
areaOfBox(3, 6);
trace("area="+_root.area);
它的结果也是 18, 只不过最后的结果是传递到 _root 下的指定变量 area 而已.下面一个例子更简单:
//计算矩形面积的函数
function simpleFunc() {
trace ("什么都没有"); //在这里前往结果
}
//测试函数
simpleFunc();
最后的输出就是 trace 中的字符串. 就是说, 函数可以既没有参数也没有前往值, 而是一系列操作的集合. 可见函数的使器具有很高的灵活性.

--------------------------------------------------------------------------------
同变量一样, 函数也可以具有全局性. 只需在声明时在前面给它加一个 _global 就可以了:
//计算矩形面积的全局函数
_global.areaOfBox = function (a, b) {
return a*b; //在这里前往结果
}
//测试函数
area = areaOfBox(3, 6);
trace("area="+area);
请留意: 在函数体中出现的关键字 this 代表的是调用函数的 MovieClip, 而不是函数体所在的 MovieClip. 这很容易被忽略而产生不期望的结果. 如果要指定 this 所代表的对象就要用到 Function.call() 和 Function.apply() 方法. 在后面的 arguments 对象引见中会讲到.
函数参数的检查

为了保证函数运转的正确性, 我们有时必须检测用户能否给了足够的或是正确类型的参数. 下面是我对上面例子进行改动后的代码:
//计算矩形面积的全局函数
_global.areaOfBox = function (a, b) {
//输出两个参数之和, 用于理解下面的 typeof 语句
trace("a+b="+(a+b));
//检测参数能否足够且类型正确
if(a==undefined || b==undefined || typeof(a+b)!="number") {
trace("<参数错误>");
return 0; //前往 0 作为错误时的结果
}
return a*b; //在这里前往结果
}
//测试函数
trace("----下面是正确的参数----");
area = areaOfBox(3, 6);
trace("area="+area);
trace("----下面是错误的参数----");
//这里为了节省篇幅, 我在命令中直接调用函数, 而不是先将前往值赋给一个变量
//其实这才是我们常用的函数调用方法
trace("area="+ areaOfBox(3, "6"));
trace("----下面是不足的参数----");
trace("area="+areaOfBox(3));
上例中我用 a==undefined 来判断 a 能否被赋值了(即能否已定义, 对于 undefined 数据类型的内容请参阅前一章的内容). 为了确保万无一失, 我还用了 b==undefined 来保证 b 也已被赋值, 两头使用一个逻辑 "或" 运算符 || 来连接这两个条件.
此外, 在这两个条件后面我又通过 typeof(a+b)!="number" 来确认参数类型能否正确(关于 typeof 关键字的信息请参考前一章). 这里我利用了 Actions cript 的一个特点: 数值与字符串相加的和会被优先做为字符串处理. 所以 a+b 中只需有一个为字符串, 那么整个 a+b 的前往值就是一个字符串, 在后面通过 typeof 来检测的结果自然就不是我们所要的 "number". 通过 trace("a+b="+(a+b)); 输出的结果可以看出这一点.

--------------------------------------------------------------------------------
在 Actions cript 中除了用户定义的函数外, 还有预定义的内建函数. 对于不同的对象, 也有不同的函数(或者说是方法)可以调用. 下面是拥有最高优先级的系统内建函数列表:
函数 说明
Boolean 将所给参数值转化为逻辑值(也叫做布尔值)
escape 将所给参数转化为字符串并用 URL 格式编码(所有非标准字符将被转化为以 % 开头的十六进制值)
eval 前往所给参数表示的对象, 参数可以是常量, 表达式, 属性等(这