解析JS中定义Function的两种实用方法


  本文标签:Function JS

  本文向大家描述一下JS两种定义Function非常常用的方法,虽然两个种方式定义出来的function调用的时候结果一样,但是中间还是有区别的,相信本文介绍一定会让你有所收获  。

  JS两种定义Function非常常用的方法

  大家都知道Javascript有两个种定义Function的方法非常常用  。

  例如

  1. functiona(){alert("a")}  
  2.  
  3. vara=function(){alert("a")}  

  虽然两个种方式定义出来的function调用的时候结果一样,但是中间还是有区别的  。举个简单的例子,假如我们要重定义a(),而且新的方法要继承a()里面所有方法并且进行其他扩展的话  。就可以明显看到这两个方式的区别了  。

  1.首先,我们先建立一个临时的变量来存储a()

  1. varb=a;  
  2.  

  然后,重新定义a()

  第一种方式:

  1. functiona(){  
  2. b();  
  3. alert("ok");  

  第二种方式:

  1. a=function(){  
  2. b();  
  3. alert("ok");  

  这是大家可以尝试发现  。第一种方式重新定义的a()会出现堆栈溢出的错误  。而第二种方式却成功保留了原来a()所执行的脚本,成功alert出了"a""ok"的字样,说明a()的方法被重定义了  。

  这里就可以很明显区分两个方式的区别了  。定义的顺序不同  。

  第一种,刚开始其实没有重新定义a这个function而在里面执行了其本身  。

  第二种方式,a=function()这里没有执行到function里面的代码a已经被重新定义了  。所以这里的重定义是有效的  。