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 相关文章推荐
[原创]静态页面也可以实现预览 列表不同的显示方式
Oct 14 Javascript
Javascript 二维数组
Nov 26 Javascript
鼠标滚轮控制网页横向移动实现思路
Mar 22 Javascript
js左右弹性滚动对联广告代码分享
Feb 19 Javascript
基于JS快速实现导航下拉菜单动画效果附源码下载
Oct 27 Javascript
JavaScript 限制文本框不可输入英文单双引号的方法
Dec 20 Javascript
vue项目总结之文件夹结构配置详解
Dec 13 Javascript
使用jQuery 操作table 完成单元格合并的实例
Dec 27 jQuery
vue-cli3 karma单元测试的实现
Jan 18 Javascript
JS中比Switch...Case更优雅的多条件判断写法
Sep 05 Javascript
js中script的上下放置区别,Dom的增删改创建操作实例分析
Dec 16 Javascript
js实现简单商品筛选功能
Feb 02 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记录用户通过搜索引擎进网站的关键词
2014/02/13 PHP
php分页代码学习示例分享
2014/02/20 PHP
Session的工作机制详解和安全性问题(PHP实例讲解)
2014/04/10 PHP
ajax+php控制所有后台函数调用
2015/07/15 PHP
编写PHP脚本清除WordPress头部冗余代码的方法讲解
2016/03/01 PHP
PHP实现批量删除(封装)
2017/04/28 PHP
浅谈php的TS和NTS的区别
2019/03/13 PHP
又一个图片自动缩小的JS代码
2007/03/10 Javascript
创建公共调用 jQuery Ajax 带返回值
2012/08/01 Javascript
用js控制组织结构图可以任意拖拽到指定位置
2014/01/17 Javascript
JQuery报错Uncaught TypeError: Illegal invocation的处理方法
2015/03/13 Javascript
浅谈Jquery中Ajax异步请求中的async参数的作用
2016/06/06 Javascript
JS多物体实现缓冲运动效果示例
2016/12/20 Javascript
纯javaScript、jQuery实现个性化图片轮播【推荐】
2017/01/08 Javascript
Node.js Event Loop各阶段讲解
2019/03/08 Javascript
简单了解JavaScript中的执行上下文和堆栈
2019/06/24 Javascript
layer.open回调获取弹出层参数的实现方法
2019/09/10 Javascript
微信小程序实现多图上传
2020/06/19 Javascript
原生js canvas实现鼠标跟随效果
2020/08/02 Javascript
Pyramid将models.py文件的内容分布到多个文件的方法
2013/11/27 Python
python 删除列表里所有空格项的方法总结
2018/04/18 Python
python requests.post带head和body的实例
2019/01/02 Python
pytorch使用Variable实现线性回归
2019/05/21 Python
java判断三位数的实例讲解
2019/06/10 Python
Python从文件中读取指定的行以及在文件指定位置写入
2019/09/06 Python
python SocketServer源码深入解读
2019/09/17 Python
分享一个pycharm专业版安装的永久使用方法
2019/09/24 Python
天地会口号
2014/06/17 职场文书
道路交通事故人身损害赔偿协议书
2014/11/19 职场文书
教师节寄语2015
2015/03/23 职场文书
加薪通知
2015/04/25 职场文书
失恋33天观后感
2015/06/11 职场文书
鲁滨逊漂流记读书笔记
2015/06/26 职场文书
Vue实现下拉加载更多
2021/05/09 Vue.js
Pytorch实现图像识别之数字识别(附详细注释)
2021/05/11 Python
十大公认最好看的动漫:《咒术回战》在榜,《钢之炼金术师》第一
2022/03/18 日漫