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 相关文章推荐
url 编码 js url传参中文乱码解决方案
Apr 11 Javascript
理解Javascript_01_理解内存分配原理分析
Oct 11 Javascript
在多个页面使用同一个HTML片段的代码
Mar 04 Javascript
js实现文本框输入文字个数限制代码
Dec 25 Javascript
百度搜索框智能提示案例jsonp
Nov 28 Javascript
基于JS实现移动端向左滑动出现删除按钮功能
Feb 22 Javascript
深入理解Vue父子组件生命周期执行顺序及钩子函数
Aug 12 Javascript
微信小程序实现留言板(Storage)
Nov 02 Javascript
Vue 实时监听窗口变化 windowresize的两种方法
Nov 06 Javascript
Vue的生命周期操作示例
Sep 17 Javascript
纯js实现无缝滚动功能代码实例
Feb 21 Javascript
jQuery实现二级导航菜单的示例
Sep 30 jQuery
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
PHP 上传文件的方法(类)
2009/07/30 PHP
php程序效率优化的一些策略小结
2010/07/17 PHP
yii使用bootstrap分页样式的实例
2017/01/17 PHP
详解PHP中curl_multi并发的实现
2020/06/08 PHP
asp 取文本框名称代码
2008/12/02 Javascript
Javascript 网页水印(非图片水印)实现代码
2010/03/01 Javascript
浅谈js函数三种定义方式 & 四种调用方式 & 调用顺序
2017/02/19 Javascript
JavaScript使用FileReader实现图片上传预览效果
2020/03/27 Javascript
vue2.0项目实现路由跳转的方法详解
2018/06/21 Javascript
微信小程序实现红包雨功能
2018/07/11 Javascript
JS多个表单数据提交下的serialize()应用实例分析
2019/08/27 Javascript
如何使用webpack打包一个库library的方法步骤
2019/12/18 Javascript
JavaScript this关键字指向常用情况解析
2020/09/02 Javascript
如何在Express4.x中愉快地使用async的方法
2020/11/18 Javascript
[12:29]2018国际邀请赛 开幕秀
2018/08/22 DOTA
python实现k均值算法示例(k均值聚类算法)
2014/03/16 Python
windows系统中python使用rar命令压缩多个文件夹示例
2014/05/06 Python
Python实现的简单发送邮件脚本分享
2014/11/07 Python
python实现百万答题自动百度搜索答案
2018/01/16 Python
Python实现的维尼吉亚密码算法示例
2018/04/12 Python
PyQt5每天必学之弹出消息框
2018/04/19 Python
python 递归深度优先搜索与广度优先搜索算法模拟实现
2018/10/22 Python
Python中常用的内置方法
2019/01/28 Python
代码实例讲解python3的编码问题
2019/07/08 Python
将tensorflow.Variable中的某些元素取出组成一个新的矩阵示例
2020/01/04 Python
python递归调用中的坑:打印有值, 返回却None
2020/03/16 Python
NBA欧洲商店(法国):NBA Europe Store FR
2016/10/19 全球购物
美体小铺美国官网:The Body Shop美国
2017/11/10 全球购物
高中化学教学反思
2014/01/13 职场文书
三好学生演讲稿范文
2014/04/26 职场文书
抗洪救灾先进集体事迹材料
2014/05/26 职场文书
电子商务求职信
2014/06/15 职场文书
博士生求职信
2014/07/06 职场文书
论文答谢词
2015/01/20 职场文书
萤火虫之墓观后感
2015/06/05 职场文书
《春酒》教学反思
2016/02/22 职场文书