本文向大家描述一下JS两种定义Function非常常用的方法,虽然两个种方式定义出来的function调用的时候结果一样,但是中间还是有区别的,相信本文介绍一定会让你有所收获。
JS两种定义Function非常常用的方法
大家都知道Javascript有两个种定义Function的方法非常常用。
例如
- functiona(){alert("a")}
- vara=function(){alert("a")}
虽然两个种方式定义出来的function调用的时候结果一样,但是中间还是有区别的。举个简单的例子,假如我们要重定义a(),而且新的方法要继承a()里面所有方法并且进行其他扩展的话。就可以明显看到这两个方式的区别了。
1.首先,我们先建立一个临时的变量来存储a()
- varb=a;
然后,重新定义a()
***种方式:
- functiona(){
- b();
- alert("ok");
- }
第二种方式:
- a=function(){
- b();
- alert("ok");
- }
这是大家可以尝试发现。***种方式重新定义的a()会出现堆栈溢出的错误。而第二种方式却成功保留了原来a()所执行的脚本,成功alert出了"a""ok"的字样,说明a()的方法被重定义了。
这里就可以很明显区分两个方式的区别了。定义的顺序不同。
***种,刚开始其实没有重新定义a这个function而在里面执行了其本身。
第二种方式,a=function()这里没有执行到function里面的代码a已经被重新定义了。所以这里的重定义是有效的。
【编辑推荐】
- JavaScript alert()函数用法说明
- JS中Array数组的三大属性用法揭秘
- prototype.js的Ajax对IE8兼容问题解决方案
- Javascript数组创建及其常见操作
- JavaScript调试工具解决IE6等多版本共存问题