JavaScript函数定义方法实例详解


Posted in Javascript onMarch 05, 2019

本文实例讲述了JavaScript函数定义方法。分享给大家供大家参考,具体如下:

JavaScript 函数定义方法

函数声明

在之前的教程中,你已经了解了函数声明的语法 :

function functionName(parameters) {
 执行的代码
}

函数声明后不会立即执行,会在我们需要的时候调用到。

function myFunction(a, b) {
  return a * b;
}

分号是用来分隔可执行JavaScript语句。

由于函数声明不是一个可执行语句,所以不以分号结束。

函数表达式

JavaScript 函数可以通过一个表达式定义。

函数表达式可以存储在变量中:

var x = function (a, b) {return a * b};

在函数表达式存储在变量后,变量也可作为一个函数使用:

var x = function (a, b) {return a * b};
var z = x(4, 3);

以上函数实际上是一个 匿名函数 (函数没有名称)。

函数存储在变量中,不需要函数名称,通常通过变量名来调用。上述函数以分号结尾,因为它是一个执行语句。

尽量避免使用 new 关键字。

函数提升(Hoisting)

在之前的教程中我们已经了解了 "hoisting(提升)"。

提升(Hoisting)是 JavaScript 默认将当前作用域提升到前面去的的行为。

提升(Hoisting)应用在变量的声明与函数的声明。

因此,函数可以在声明之前调用:

myFunction(5);
function myFunction(y) {
  return y * y;
}

使用表达式定义函数时无法提升。

自调用函数

函数表达式可以 "自调用"。

自调用表达式会自动调用。

如果表达式后面紧跟 () ,则会自动调用。

不能自调用声明的函数。

通过添加括号,来说明它是一个函数表达式:

(function () {
  var x = "Hello!!";   // 我将调用自己
})();

以上函数实际上是一个 匿名自我调用的函数 (没有函数名)。

函数可作为一个值使用

JavaScript 函数作为一个值使用:

function myFunction(a, b) {
  return a * b;
}
var x = myFunction(4, 3);

JavaScript 函数可作为表达式使用:

function myFunction(a, b) {
  return a * b;
}
var x = myFunction(4, 3) * 2;

函数是对象

在 JavaScript 中使用 typeof 操作符判断函数类型将返回 "function" 。

但是JavaScript 函数描述为一个对象更加准确。

JavaScript 函数有 属性方法

arguments.length 属性返回函数调用过程接收到的参数个数:

function myFunction(a, b) {
  return arguments.length;
}

toString() 方法将函数作为一个字符串返回:

function myFunction(a, b) {
  return a * b;
}
var txt = myFunction.toString();

更多关于JavaScript相关内容可查看本站专题:《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
List the Codec Files on a Computer
Jun 18 Javascript
jquery向.ashx文件post中文乱码问题的解决方法
Mar 28 Javascript
js图片向右一张张滚动效果实例代码
Nov 23 Javascript
jquery 取子节点及当前节点属性值的方法
Aug 24 Javascript
AngularJS中的模块详解
Jan 29 Javascript
原生js实现图片层叠轮播切换效果
Feb 02 Javascript
怎么引入(调用)一个JS文件
May 26 Javascript
bootstrap模态框消失问题的解决方法
Dec 02 Javascript
Bootstrap基本插件学习笔记之按钮(21)
Dec 08 Javascript
JavaScript实现数组降维详解
Jan 05 Javascript
简单明了区分escape、encodeURI和encodeURIComponent
May 26 Javascript
Angular单元测试之事件触发的实现
Jan 20 Javascript
C#程序员入门学习微信小程序的笔记
Mar 05 #Javascript
JavaScript函数的4种调用方法实例分析
Mar 05 #Javascript
微信小程序保存多张图片的实现方法
Mar 05 #Javascript
JS添加或删除HTML dom元素的方法实例分析
Mar 05 #Javascript
迅速了解一下ES10中Object.fromEntries的用法使用
Mar 05 #Javascript
es6数据变更同步到视图层的方法
Mar 04 #Javascript
使用webpack构建应用的方法步骤
Mar 04 #Javascript
You might like
ThinkPHP连接数据库及主从数据库的设置教程
2014/08/22 PHP
PHP下载远程图片并保存到本地方法总结
2016/01/22 PHP
浅谈PHP中的那些魔术常量
2020/12/02 PHP
DEFER怎么用?
2006/07/01 Javascript
如何用js控制css中的float的代码
2007/08/16 Javascript
javascript开发中因空格引发的错误
2010/11/08 Javascript
jquery如何改变html标签的样式(两种实现方法)
2013/01/16 Javascript
jquery实现input输入框实时输入触发事件代码
2014/01/28 Javascript
javascript实现动态侧边栏代码
2014/02/19 Javascript
ajax请求乱码的解决方法(中文乱码)
2014/04/10 Javascript
原生js实现移动端瀑布流式代码示例
2015/12/18 Javascript
20分钟打造属于你的Bootstrap站点
2016/07/27 Javascript
使用JS实现图片展示瀑布流效果的实例代码
2016/09/12 Javascript
js点击按钮实现水波纹效果代码(CSS3和Canves)
2016/09/15 Javascript
Ajax的概述与实现过程
2016/11/18 Javascript
jquery dataview数据视图插件使用方法
2016/12/23 Javascript
Bootstrap和Java分页实例第二篇
2016/12/23 Javascript
JavaScript无缝滚动效果的实例代码
2017/03/27 Javascript
vue和react等项目中更简单的实现展开收起更多等效果示例
2018/02/22 Javascript
JS获取并处理php数组的方法实例分析
2018/09/04 Javascript
Vue 页面权限控制和登陆验证功能的实例代码
2019/06/20 Javascript
jQuery插件实现图片轮播效果
2020/10/19 jQuery
[01:20:06]TNC vs VG 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
Python中利用sorted()函数排序的简单教程
2015/04/27 Python
Python实现Kmeans聚类算法
2020/06/10 Python
python之从文件读取数据到list的实例讲解
2018/04/19 Python
pygame游戏之旅 载入小车图片、更新窗口
2018/11/20 Python
Django model反向关联名称的方法
2018/12/15 Python
使用Flask-Cache缓存实现给Flask提速的方法详解
2019/06/11 Python
CSS3实现类似翻书效果的过渡动画的示例代码
2019/09/06 HTML / CSS
流行文化收藏品:Sideshow(DC漫画,星球大战,漫威)
2019/03/17 全球购物
2014年新生军训方案
2014/05/01 职场文书
我爱祖国演讲稿
2014/09/02 职场文书
2014财务部年度工作总结
2014/12/08 职场文书
2014年工商所工作总结
2014/12/09 职场文书
AudioContext 实现音频可视化(web技术分享)
2022/02/24 Javascript