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面向对象之Prototypes和继承
Jul 12 Javascript
ExtJS判断IE浏览器类型的方法
Feb 10 Javascript
Enter回车切换输入焦点实现思路与代码兼容各大浏览器
Sep 01 Javascript
JavaScript使用encodeURI()和decodeURI()获取字符串值的方法
Aug 04 Javascript
javascript中checkbox使用方法实例演示
Nov 19 Javascript
js获取鼠标点击的对象,点击另一个按钮删除该对象的实现代码
May 13 Javascript
Javascript blur与click冲突解决办法
Jan 09 Javascript
vue2.0使用Sortable.js实现的拖拽功能示例
Feb 21 Javascript
Vue.js实现模拟微信朋友圈开发demo
Apr 20 Javascript
js实现简单的随机点名器
Sep 17 Javascript
Vue切换Tab动态渲染组件的操作
Sep 21 Javascript
如何使用CocosCreator对象池
Apr 14 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 ftp文件上传函数(基础版)
2010/06/03 PHP
PHP 通过Socket收发十六进制数据的实现代码
2013/08/16 PHP
php计算两个整数的最大公约数常用算法小结
2015/03/05 PHP
php实现的数字验证码及数字运算验证码
2015/07/30 PHP
JavaScript 函数式编程的原理
2009/10/16 Javascript
JSON辅助格式化处理方法
2013/03/26 Javascript
Jquery同辈元素选中/未选中效果的实例代码
2013/08/01 Javascript
javascript(js)的小数点乘法除法问题详解
2014/03/07 Javascript
JavaScript中Date对象的常用方法示例
2015/10/24 Javascript
浅谈JavaScript中数组的增删改查
2016/06/20 Javascript
chrome下判断点击input上标签还是其余标签的实现方法
2016/09/18 Javascript
JS两种类型的表单提交方法实例分析
2016/11/28 Javascript
JS实现的简易拖放效果示例
2016/12/29 Javascript
JavaScript实现简易的天数计算器实例【附demo源码下载】
2017/01/18 Javascript
Vue的土著指令和自定义指令实例详解
2018/02/04 Javascript
适合前端Vue开发童鞋的跨平台Weex的使用详解
2019/10/16 Javascript
vue之封装多个组件调用同一接口的案例
2020/08/11 Javascript
Node在Controller层进行数据校验的过程详解
2020/08/28 Javascript
PyQt5打开文件对话框QFileDialog实例代码
2018/02/07 Python
Django开发中复选框用法示例
2018/03/20 Python
关于python2 csv写入空白行的问题
2018/06/22 Python
Python如何访问字符串中的值
2020/02/09 Python
django使用F方法更新一个对象多个对象字段的实现
2020/03/28 Python
Django实现whoosh搜索引擎使用jieba分词
2020/04/08 Python
python如何实现递归转非递归
2021/02/25 Python
css3编写浏览器背景渐变背景色的方法
2018/03/05 HTML / CSS
车辆安全检查制度
2014/01/12 职场文书
运动会入场词200字
2014/02/15 职场文书
护理专业毕业生自我鉴定总结
2014/03/24 职场文书
开学寄语大全
2014/04/08 职场文书
2014年妇幼保健工作总结
2014/12/08 职场文书
荆州古城导游词
2015/02/06 职场文书
毕业生捐书活动倡议书
2015/04/27 职场文书
企业文化学习心得体会
2016/01/21 职场文书
mysql联合索引的使用规则
2021/06/23 MySQL
一篇文章带你复习java知识点
2021/06/28 Java/Android