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

开发 前端
Javascript有两个种定义Function的方法非常常用,这里和大家分享一下,虽然两个种方式定义出来的function调用的时候结果一样,但是中间还是有区别的。

本文向大家描述一下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已经被重新定义了。所以这里的重定义是有效的。

【编辑推荐】

  1. JavaScript alert()函数用法说明
  2. JS中Array数组的三大属性用法揭秘
  3. prototype.js的Ajax对IE8兼容问题解决方案
  4. Javascript数组创建及其常见操作
  5. JavaScript调试工具解决IE6等多版本共存问题 


 

责任编辑:佚名 来源: webshu.net
相关推荐

2009-12-07 13:42:24

WCF框架

2010-07-02 10:28:41

虚拟化桌面虚拟化

2011-03-03 17:00:37

pure-ftpdchroot

2011-02-23 12:49:31

KonquerorEmbedded

2010-07-27 15:03:37

Flex ArrayC

2010-03-15 15:30:35

Python模块

2009-06-08 20:07:44

Eclipse中使用p

2010-08-11 14:22:26

Flex弹出窗口

2011-08-08 14:13:47

iPhone XML NSXMLParse

2020-02-21 17:33:17

SparkKafka数据

2010-10-14 14:33:15

MySQL多表联查

2011-06-23 09:07:16

2012-10-16 09:40:38

洗牌算法

2011-08-09 13:50:01

iPhone动画UIView

2010-09-17 09:37:27

Java安装方法

2010-03-17 10:18:05

Linux系统

2010-03-17 10:48:43

Linux系统

2010-03-17 10:42:18

Linux系统

2010-03-17 10:35:32

Linux系统

2010-07-13 14:54:15

Perl面向对象编程
点赞
收藏

51CTO技术栈公众号