解析JS中定义Function的两种实用方法 |
本文标签:Function JS 本文向大家描述一下JS两种定义Function非常常用的方法,虽然两个种方式定义出来的function调用的时候结果一样,但是中间还是有区别的,相信本文介绍一定会让你有所收获 。 JS两种定义Function非常常用的方法 大家都知道Javascript有两个种定义Function的方法非常常用 。 例如
虽然两个种方式定义出来的function调用的时候结果一样,但是中间还是有区别的 。举个简单的例子,假如我们要重定义a(),而且新的方法要继承a()里面所有方法并且进行其他扩展的话 。就可以明显看到这两个方式的区别了 。 1.首先,我们先建立一个临时的变量来存储a()
然后,重新定义a() 第一种方式:
第二种方式:
这是大家可以尝试发现 。第一种方式重新定义的a()会出现堆栈溢出的错误 。而第二种方式却成功保留了原来a()所执行的脚本,成功alert出了"a""ok"的字样,说明a()的方法被重定义了 。 这里就可以很明显区分两个方式的区别了 。定义的顺序不同 。 第一种,刚开始其实没有重新定义a这个function而在里面执行了其本身 。 第二种方式,a=function()这里没有执行到function里面的代码a已经被重新定义了 。所以这里的重定义是有效的 。 |