Javascript--函数技巧

最近在看JavaScript,把函数部分总结一下:
函数是一段只被定义一次,但是可能被执行或调用多次的Javascript代码。
函数如果挂载在一个对象上,作为对象的一个属性,就称它为对象的方法。当通过这个对象来调用函数时,该对象就是此次调用的上下文(context)。

一、函数的申明

使用function关键字:

function a(){
    alert("It is my first try about function in JS");
}

跟JAVA、C等语言不同,JavaScript的函数没有类型名,直接一个关键字function加上函数名就实现了对一个函数的申明。
甚至,并不需要一个函数名:

var a = function(){
alert("我是一个匿名函数");
}

构造器方法

var sum=new Function('a','b','return a+b');

二、函数的参数

“Javascript中的函数定义并未指定函数形参的类型,函数调用也未对传入的实参值做任何类型检查。实际上,javascript函数调用甚至不检查传入参数的个数。”
每个函数都有一个length属性,长度是接收参数的个数
firebug中调试示例:

>>>function sum(b,c){return b+c;}
>>>sum.length
2

函数的参数存储在它的内建数组arguments中
下面的示例我们将sum函数的参数返回回来:

>>>function sum(a,b){return arguments;}
>>>sum(2,4)
[2,4]

函数调用时,忘了传递相关的参数值,系统会将其设定为undefined

>>>function sum(a,b){return b;};
>>>sum(2)
undefined

利用arguments和length实现一个接收任何个数参数的sum函数

function sum(){
    var result;
    for(var i=0;i<sum.length;i++)
        result +=arguments[i];
    return result;
}

三、函数也是一种数据!!!

JavaScript有一点让人难以接受的–函数也当成一种数据对待。
所以,下面两种函数定义的方法完全等价:

function f(){return 1;}

var f=function(){return 1;}

函数也是一种数据的做法同时也能在下面体现:
将函数作为函数的返回值:

function a(){
 return function(){alert("b");}
 }

上面提到函数能返回函数,那么我们让函数重写自己怎么样?

function a(){
//dosomething
    alert("I am used to do A");
    function b(){
    //do something
    alert("I am used to do B");
    }
    a=b;
}

我们多次调用a函数,只有第一次会弹出“I am used to do A”。后面则是”I am used to do B”。
这种重写自己的技巧对于完成一些初始化工作非常有用。换句话说,有些情景只需要初始化一次参数,那么重复调用程序的话,避免一些不必要的操作。

四、自调函数

自调函数在定义之后就被执行!
自调函数由一对括号括起来的匿名函数和紧跟其后的一对括号组成:
如下

(function(SomeParameter){

//do something

})(SomeParameter)

第二对括号起到“立即调用”的作用,同时也是向匿名函数传递参数的地方。
下面是一个自调函数的例子:

str="xiaowang"

(function Welcome(name){
    alert("welcome " + name);
})(str)

如果我们将其放在登陆成功后的欢迎页,只需要让str接收用户名就好了,就能完成欢迎提示。
可以看到:自调函数不会产生任何全局变量,同时它的执行也不需要可以去调用。但是,这样的函数是无法重复执行的。

五、内部函数

简单的讲,内部函数定义在函数内部:

function a(){
    function b(str){
        alert("Hello world" + str);
    }
    return b("wang");
}

上面的b就是一个内部函数,它在a函数之外是不可见的,所以也叫私有函数。

六:函数中变量的提升现象

函数被执行时,所有内部定义的变量的定义会最先执行,这种现象叫做提升(hoisting)。这中函数执行方式带来一些让初学者摸不着头脑的现象:

var a=123;
function test(){
alert(a);
var a = 23;
}
test();

上面一段代码执行后,会弹出undefined,而不是123。因为提升现象,实际函数是这样执行的:

var a = 123;
function test(){
var a;//变量的申明提到函数开头,
alert(a);
a= 123;//赋值操作仍在原来位置
}
test();
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值