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 相关文章推荐
自己的js工具_Form 封装
Aug 21 Javascript
jQuery事件 delegate()使用方法介绍
Oct 30 Javascript
浅谈jQuery中 wrap() wrapAll() 与 wrapInner()的差异
Nov 12 Javascript
12个非常实用的JavaScript小技巧【推荐】
May 18 Javascript
JS中的hasOwnProperty()、propertyIsEnumerable()和isPrototypeOf()
Aug 11 Javascript
vue v-model动态生成详解
Jun 30 Javascript
深入理解JS中Number(),parseInt(),parseFloat()三者比较
Aug 24 Javascript
react写一个select组件的实现代码
Apr 03 Javascript
ElementUI Tag组件实现多标签生成的方法示例
Jul 08 Javascript
Layui数据表格判断编辑输入的值,是否为我需要的类型详解
Oct 26 Javascript
茶余饭后聊聊Vue3.0响应式数据那些事儿
Oct 30 Javascript
vue Tab切换以及缓存页面处理的几种方式
Nov 05 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
Symfony2在Nginx下的配置方法图文教程
2016/02/04 PHP
PHP实现的文件浏览器功能简单示例
2019/09/12 PHP
安装PHP扩展时解压官方 tgz 文件后没有configure文件无法进行配置编译的问题
2020/08/26 PHP
js几个验证函数代码
2010/03/25 Javascript
各情景下元素宽高的获取实现代码
2011/09/13 Javascript
深入分析js中的constructor和prototype
2012/04/07 Javascript
JS实现文件动态顺序载入的方法
2015/03/07 Javascript
微信jssdk用法汇总
2016/07/16 Javascript
js中数组的常用方法小结
2016/12/30 Javascript
jQuery实现一个简单的轮播图
2017/02/19 Javascript
vue 2.0 购物车小球抛物线的示例代码
2018/02/01 Javascript
jQuery基于Ajax实现读取XML数据功能示例
2018/05/31 jQuery
jQuery实现图片简单轮播功能示例
2018/08/13 jQuery
微信小程序功能之全屏滚动效果的实现代码
2018/11/22 Javascript
详解基于原生JS验证表单组件xy-form
2019/08/20 Javascript
微信小程序加载机制及运行机制图解
2019/11/27 Javascript
解决vue-router 切换tab标签关闭时缓存问题
2020/07/22 Javascript
python正则匹配查询港澳通行证办理进度示例分享
2013/12/27 Python
Python与人工神经网络:使用神经网络识别手写图像介绍
2017/12/19 Python
redis之django-redis的简单缓存使用
2018/06/07 Python
Python的高阶函数用法实例分析
2019/04/11 Python
用uWSGI和Nginx部署Flask项目的方法示例
2019/05/05 Python
python实现几种归一化方法(Normalization Method)
2019/07/31 Python
Django中自定义查询对象的具体使用
2019/10/13 Python
win10子系统python开发环境准备及kenlm和nltk的使用教程
2019/10/14 Python
Python3 搭建Qt5 环境的方法示例
2020/07/16 Python
PyQt5中QSpinBox计数器的实现
2021/01/18 Python
python爬虫利用代理池更换IP的方法步骤
2021/02/21 Python
纯CSS3制作漂亮带动画效果的主机价格表
2015/04/25 HTML / CSS
html5 css3实例教程 一款html5和css3实现的小机器人走路动画
2014/10/20 HTML / CSS
G-Form护具官方网站:美国运动保护装备
2019/09/04 全球购物
美国最大和最受信任的二手轮胎商店:Bestusedtires.com
2020/06/02 全球购物
医院总经理职责
2013/12/26 职场文书
优秀少先队工作者事迹材料
2014/05/13 职场文书
趣味运动会简讯
2015/07/20 职场文书
百日宴上的祝酒词
2015/08/10 职场文书