浅析JS中对函数function的理解(基础篇)


Posted in Javascript onOctober 14, 2016

正文:我们知道,在js中,函数实际上是一个对象,每个函数都是Function类型的实例,并且都与其他引用类型一样具有属性和方法。因此,函数名实际上是指向函数对象的指针,不与某个函数绑定。在常见的两种定义方式(见下文)之外,还有一种定义的方式能更直观的体现出这个概念:

var sum = new Function("num1", "num2", "return num1 + num2"); //不推荐

Function的构造函数可以接收任意数量的参数,但最后一个参数始终被看做函数体。这种方式有个缺点是,会导致解析两次代码,第一次是基础的ES代码解析,第二次是解析传入构造函数中的字符串,这样会导致性能的下降,在此写出是帮助理解js中函数其实是对象这个概念。

 (一)js函数没有重载的概念

说到重载的概念,我们来类比Java中的重载是怎么实现的:在Java中,方法是通过方法签名来唯一标识一个方法。方法签名包括:方法名、参数数量、参数顺序和参数类型这几个要素。因此两个方法的方法名相同,而其他签名要素不同,编译器就会认为是两个不同方法,从而可以存在同名的不同方法,以实现重载的概念。(引用:怎么深入理解js中为什么没有重载呢--segmentfault 中manxisuo的回答)。

而上面我们说过,js中的函数名实际上是指向函数对象的指针,因此函数名可以说是一个函数的唯一标识,跟参数列表并没有关系,因此并不会出现同名的两个函数(因为一个指针同时只能指向一个对象)从而不存在重载的概念。 举个栗子:

function sum(num1, num2){
return num1 + num2;
}
function sum(num1, num2, num3){
return num1 + num2 + num3;
}

上面这种可以换一种写法,会更直观一些:

var sum = function(num1, num2){
return num1 + num2;
}
sum = function(num1, num2, num3){
return num1 + num2 + num3;
}

这样就很明显可以看出,上面一行将sum指向function(num1,num2),而接下来又将sum指向function(num1, num2, num3),从而造成第二次的指向覆盖了第一次的,因此更明显的看出js中并没有重载的概念。

(二)函数声明和函数表达式的区别

我们知道,常用的定义函数方法有两个:函数声明和函数表达式。

函数声明,可以说是最常见的定义方法,如下例:

function sum(num1, num2){
return num1 + num2;
}

函数表达式,这种定义方式在闭包及一些框架中使用较多,例如angular中常见的$scope.doSomething = function(){...}:

sum = function(num1, num2){
return num1 + num2;
};

上述两种定义方法几乎是相同的,但有一点小区别,请看下面这个例子:

//函数声明
alert(sum(100, 100));
function sum(num1, num2){
return num1 + num2;
}
//函数表达式
alert(sum(100, 100));
var sum = function(num1, num2){
return num1 + num2;
};

这两段代码看起来差别不大,只是函数定义的方式不同而已。但事实是,第一段可以正常运行而第二段则会报错。这是因为,在代码开始执行之前,解析器就已经通过一个名为函数声明提升的过程,读取并将函数声明添加到执行环境中。简单来说,解析器会先将函数声明放在源代码树的顶部。而下面那段代码,函数位于一个初始化语句中(并不会将其提升到顶部),简单来说,在执行到这个赋值语句之前,sum并未指向任何一个函数,因此在之前调用函数则会报错。

以上所述是小编给大家介绍的JS中函数function的理解(基础篇),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
验证码按回车不变解决方法
Mar 29 Javascript
js获取和设置属性的方法
Feb 20 Javascript
jQuery中innerWidth()方法用法实例
Jan 19 Javascript
原生JavaScript实现Ajax的方法
Apr 07 Javascript
Javascript计算二维数组重复值示例代码
Dec 18 Javascript
详解js前端代码异常监控
Jan 11 Javascript
AngularJS中的缓存使用
Jan 11 Javascript
js+html5实现半透明遮罩层弹框效果
Aug 24 Javascript
vue-cli中安装方法(图文详细步骤)
Dec 12 Javascript
JavaScript遍历查找数组中最大值与最小值的方法示例
May 24 Javascript
在vue中利用v-html按分号将文本换行的例子
Nov 14 Javascript
vue通过v-html指令渲染的富文本无法修改样式的解决方案
May 20 Javascript
js插件Jcrop自定义截取图片功能
Oct 14 #Javascript
jQuery.form.js插件不能解决连接超时(timeout)的原因分析及解决方法
Oct 14 #Javascript
Js动态设置rem来实现移动端字体的自适应代码
Oct 14 #Javascript
JS动态计算移动端rem的解决方案
Oct 14 #Javascript
javascript对浅拷贝和深拷贝的详解
Oct 14 #Javascript
jQuery web 组件 后台日历价格、库存设置的代码
Oct 14 #Javascript
第一次接触神奇的Bootstrap
Oct 14 #Javascript
You might like
PHP文件上传问题汇总(文件大小检测、大文件上传处理)
2015/12/24 PHP
PHP使用自定义方法实现数组合并示例
2016/07/07 PHP
MooTools 1.2介绍
2009/09/14 Javascript
web网页按比例显示图片实现原理及js代码
2013/08/09 Javascript
jquery 判断滚动条到达了底部和顶端的方法
2014/04/02 Javascript
JavaScript实现列出数组中最长的连续数
2014/12/29 Javascript
javascript弹性运动效果简单实现方法
2016/01/08 Javascript
js HTML5 Ajax实现文件上传进度条功能
2016/02/13 Javascript
javascript截图 jQuery插件imgAreaSelect使用详解
2016/05/04 Javascript
jquery easyui datagrid实现增加,修改,删除方法总结
2016/05/25 Javascript
AngularJS的ng-click传参的方法
2017/06/19 Javascript
vue.js移动数组位置,同时更新视图的方法
2018/03/08 Javascript
微信小程序解除10个请求并发限制
2018/12/18 Javascript
layui上传图片到服务器的非项目目录下的方法
2019/09/26 Javascript
基于JavaScript实现表格隔行换色
2020/05/08 Javascript
使用JavaScript实现网页秒表功能(含开始、暂停、继续、重置功能)
2020/06/05 Javascript
微信小程序拖拽排序列表的示例代码
2020/07/08 Javascript
OpenLayers3实现图层控件功能
2020/09/25 Javascript
[02:32]DOTA2完美大师赛场馆静安体育中心观赛全攻略
2017/11/08 DOTA
Python批量更改文件名的实现方法
2017/10/29 Python
Python类的继承和多态代码详解
2017/12/27 Python
Python编程实现从字典中提取子集的方法分析
2018/02/09 Python
如何优雅地改进Django中的模板碎片缓存详解
2018/07/04 Python
学生信息管理系统Python面向对象版
2019/01/30 Python
python 实现两个npy档案合并
2020/07/01 Python
python使用隐式循环快速求和的实现示例
2020/09/11 Python
关于pycharm 切换 python3.9 报错 ‘HTMLParser‘ object has no attribute ‘unescape‘ 的问题
2020/11/24 Python
Numpy中np.max的用法及np.maximum区别
2020/11/27 Python
Vision Directa智利眼镜网:框架眼镜、隐形眼镜和名牌太阳眼镜
2016/11/23 全球购物
环保倡议书
2014/04/14 职场文书
揭牌仪式策划方案
2014/05/28 职场文书
趣味运动会广播稿
2015/08/19 职场文书
2016年教育局“我们的节日——端午节”主题活动总结
2016/04/01 职场文书
在K8s上部署Redis集群的方法步骤
2021/04/27 Redis
Nginx+Tomcat负载均衡多实例详解
2022/04/11 Servers
Python绘制散乱的点构成的图的方法
2022/04/21 Python