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 相关文章推荐
从父页面读取和操作iframe中内容方法
Jul 25 Javascript
js 设置选中行的样式的实现代码
May 24 Javascript
jq实现左侧显示图片右侧文字滑动切换效果
Aug 04 Javascript
jQuery插件MovingBoxes实现左右滑动中间放大图片效果
Feb 28 Javascript
webpack2.0搭建前端项目的教程详解
Apr 05 Javascript
vue组件 $children,$refs,$parent的使用详解
Jul 31 Javascript
JavaScript数据结构与算法之队列原理与用法实例详解
Nov 22 Javascript
11行JS代码制作二维码生成功能
Mar 09 Javascript
详解webpack4多入口、多页面项目构建案例
May 25 Javascript
node.js使用免费的阿里云ip查询获取ip所在地【推荐】
Sep 03 Javascript
详解JavaScript匿名函数和闭包
Jul 10 Javascript
JS运算符优先级与表达式示例详解
Sep 04 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
php出现Cannot modify header information问题的解决方法大全
2008/04/09 PHP
如何使用PHP实现javascript的escape和unescape函数
2013/06/29 PHP
兼容IE和FF的js脚本代码小结(比较常用)
2010/12/06 Javascript
js+数组实现网页上显示时间/星期几的实用方法
2013/01/18 Javascript
Javascript中的arguments与重载介绍
2015/03/15 Javascript
javascript实现动态改变层大小的方法
2015/05/14 Javascript
js实现继承的5种方式
2015/12/01 Javascript
基于JavaScript获取鼠标位置的各种方法
2015/12/16 Javascript
jQuery hover事件简单实现同时绑定2个方法
2016/06/07 Javascript
Javascript 高性能之递归,迭代,查表法详解及实例
2017/01/08 Javascript
在vue.js中抽出公共代码的方法示例
2017/06/08 Javascript
JS无限级导航菜单实现方法
2019/01/05 Javascript
前端路由&webpack基础配置详解
2019/06/10 Javascript
js全屏事件fullscreenchange 实现全屏、退出全屏操作
2019/09/17 Javascript
用JS实现选项卡
2020/03/23 Javascript
JavaScript 接口原理与用法实例详解
2020/05/12 Javascript
[02:51]2014DOTA2 TI小组赛总结中国军团全部进军钥匙球馆
2014/07/15 DOTA
[01:06:39]DOTA2上海特级锦标赛主赛事日 - 1 胜者组第一轮#1Liquid VS Alliance第三局
2016/03/02 DOTA
Python中使用语句导入模块或包的机制研究
2015/03/30 Python
在Python中使用__slots__方法的详细教程
2015/04/28 Python
python正则表达式的使用
2017/06/12 Python
python数字图像处理之高级滤波代码详解
2017/11/23 Python
Python通过Pygame绘制移动的矩形实例代码
2018/01/03 Python
Python实现处理逆波兰表达式示例
2018/07/30 Python
numpy.ndarray 交换多维数组(矩阵)的行/列方法
2018/08/02 Python
详解Numpy数组转置的三种方法T、transpose、swapaxes
2019/05/27 Python
Django Rest framework三种分页方式详解
2019/07/26 Python
django之对FileField字段的upload_to的设定方法
2019/07/28 Python
后勤管理员岗位职责
2014/08/27 职场文书
优秀高中学生评语
2014/12/30 职场文书
同学毕业留言寄语
2015/02/27 职场文书
2015年新教师工作总结
2015/04/28 职场文书
结婚幸福感言
2015/08/01 职场文书
JavaScript 反射学习技巧
2021/10/16 Javascript
Apache Pulsar集群搭建部署详细过程
2022/02/12 Servers
使用Python解决图表与画布的间距问题
2022/04/11 Python