首页 > 语言 > JavaScript > 正文

JavaScript 高级篇之函数 (四)

2024-05-06 14:22:11
字体:
来源:转载
供稿:网友
1、函数的创建

由于前面已经用了很多的函数,我就不在这里多分享了。

2、嵌套函数
代码如下:
function china()
{
function people()//嵌套函数,只有china用它
{
document.write("我的心愿是当杜甫,最近网上他的漫画,他活的好潇洒");
}
people();
}

3、函数的直接量

Javascript允许函数用直接量来定义,说白了就是一个表达式,(匿名函数)。细节:匿名函数以后会用,要明白!
代码如下:
function china(people) //函数声明
{
return peole;
}
var fun = function(people){return people;};//通过表达式声明。效果等同

4、函数的参数(这里大家要注意)

当你调用一个函数的参数少于声明的参数个数是,其它的参数就是一个undefined的值。
代码如下:
//打印函数
function displayArray(arr)
{
if(!arr)return;
for(var num =0;num<arr.length;num++)
{
document.write("Num is "+ arr[num]+ "/t");
}
document.write(" "+"<br />");
}
var array = [2,32,14,57,6];
function borrowArray(from,/*optional*/to)
{
if(!to) to = []; //to = to||[] 效果是等同的
for(var element in from) //使用枚举遍历数组
to.push(from[element]);//将元素添加到数组
return to;//返回
}
var returnnumber = borrowArray(array);//执行
displayArray(returnnumber);//打印
//输出:Num is 2 Num is 32 Num is 14 Num is 57 Num is 6

5、可变的参数(Arguments 对象)
第一次看到这里我也晕了,怎么参数还变的呢,多白了,这个argument对象就是函数参数的管理者,比如你有一个函数,定义了3个参数,那argument就有一个和你定义的参数,一样的数据集。
要注意:arguments标识符在函数体内才有效的。你也可以就把它当成是函数的属性吧!
代码如下:
function checkArgument(x,y,z)
{
if(arguments.length != 3) throw new Error("参数不匹配"); //检查参数是否合法,挺好用吧!
return x+y+z;
}

下面的例子是一个比较数字大小的例子,参数是可以变的。
代码如下:
function compareMaxNumber()
{
var temp = Number.NEGATIVE_INFINITY;//表示javascript最小的复数
for(var arg=0;arg<arguments.length;arg++)
{
if(arguments[arg]>temp) temp = arguments[arg];
}
return temp; //返回参数中最大的数字
}
document.write(compareMaxNumber(2,34,5,23,766,1000)+"<br />");//这里的参数可以有很多,输出1000

6、将对象属性作为参数
代码如下:
function displayArray(arr) //打印函数
{
if(!arr)return;
for(var num =0;num<arr.length;num++)
{
document.write("Num is "+ arr[num]+ "/t");
}
document.write(" "+"<br />");
}
//
function copyArray(from,from_start,to,to_start,length)//复制数组
{
for(var i = from_start; i <length;i++)
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选