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 相关文章推荐
javascript 数组学习资料收集
Apr 11 Javascript
读jQuery之十四 (触发事件核心方法)
Aug 23 Javascript
纯js实现瀑布流展现照片(自动适应窗口大小)
Apr 08 Javascript
node.js中的events.emitter.removeAllListeners方法使用说明
Dec 10 Javascript
JavaScript精炼之构造函数 Constructor及Constructor属性详解
Nov 05 Javascript
AngularJS入门之动画
Jul 27 Javascript
Centos7 中 Node.js安装简单方法
Nov 02 Javascript
vue-resource 拦截器使用详解
Feb 21 Javascript
angular2实现统一的http请求头方法
Aug 13 Javascript
基于JavaScript实现每日签到打卡轨迹功能
Nov 29 Javascript
vue使用axios上传文件(FormData)的方法
Apr 14 Javascript
JS拖动选择table里的单元格完整实例【基于jQuery】
May 28 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
初探PHP5
2006/10/09 PHP
gd库图片下载类实现下载网页所有图片的php代码
2012/08/20 PHP
解析:php调用MsSQL存储过程使用内置RETVAL获取过程中的return值
2013/07/03 PHP
PHP+MYSQL会员系统的开发实例教程
2014/08/23 PHP
PHP数据对象映射模式实例分析
2019/03/29 PHP
JavaScript效率调优经验
2009/06/04 Javascript
IE中radio 或checkbox的checked属性初始状态下不能选中显示问题
2009/07/25 Javascript
jQuery UI 实现email输入提示实例
2013/08/15 Javascript
Jquery 切换不同图片示例代码
2013/12/05 Javascript
js实现连个数字相加而不是拼接的方法
2014/02/23 Javascript
Jquery 在页面加载后执行的几种方式
2014/03/14 Javascript
使用typeof方法判断undefined类型
2014/09/09 Javascript
谈谈target=_new和_blank的不同之处
2016/10/25 Javascript
HTML5canvas 绘制一个圆环形的进度表示实例
2016/12/16 Javascript
在node中如何使用 ES6
2017/04/22 Javascript
BootStrap Table前台和后台分页对JSON格式的要求
2017/06/28 Javascript
基于vue-element组件实现音乐播放器功能
2018/05/06 Javascript
element-ui表格列金额显示两位小数的方法
2018/08/24 Javascript
react写一个select组件的实现代码
2019/04/03 Javascript
Ubuntu 16.04 LTS中源码安装Python 3.6.0的方法教程
2016/12/27 Python
浅谈图像处理中掩膜(mask)的意义
2020/02/19 Python
Python操作Excel的学习笔记
2021/02/18 Python
CSS3 3D位移translate效果实例介绍
2016/05/03 HTML / CSS
html5版canvas自由拼图实例
2014/10/15 HTML / CSS
欧洲最大的美妆零售网站:Feelunique
2017/01/14 全球购物
美国正版电视节目和电影在线观看:Hulu
2018/05/24 全球购物
幼儿教师考核制度
2014/01/25 职场文书
中式面点餐厅创业计划书
2014/01/29 职场文书
质量安全标语
2014/06/07 职场文书
相亲活动方案
2014/08/26 职场文书
感恩老师演讲稿400字
2014/08/28 职场文书
群众路线党员自我评议范文2014
2014/09/24 职场文书
单位员工收入证明样本
2014/10/09 职场文书
领导干部作风整顿剖析材料
2014/10/11 职场文书
环境建议书
2015/02/04 职场文书
python基于tkinter制作无损音乐下载工具
2021/03/29 Python