龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > web编程 > Javascript编程 >

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

时间:2013-03-06 14:58来源:未知 作者:admin 点击:
分享到:
本文向大家描述一下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已经被重新定义了。所以这里的重定义是有效的。


 

精彩图集

赞助商链接