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入门·图片对象(无刷新变换图片)\滚动图像
Oct 01 Javascript
cookie丢失问题(认证失效) Authentication (用户验证信息)也会丢失
Jun 04 Javascript
jQuery中调用WebService方法小结
Mar 28 Javascript
javascript+ajax实现产品页面加载信息
Jul 09 Javascript
JavaScript开发者必备的10个Sublime Text插件
Feb 27 Javascript
基于canvas粒子系统的构建详解
Aug 31 Javascript
js数组实现权重概率分配
Sep 12 Javascript
Node.js使用MySQL连接池的方法实例
Feb 11 Javascript
Node.js log4js日志管理详解
Jul 31 Javascript
详解jQuery中的easyui
Sep 02 jQuery
解决layui的input独占一行的问题
Sep 10 Javascript
微信小程序可滑动月日历组件使用详解
Oct 21 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下使用curl模拟用户登陆的代码
2010/09/10 PHP
解析php中var_dump,var_export,print_r三个函数的区别
2013/06/21 PHP
php判断当前操作系统类型
2015/10/28 PHP
Laravel 中使用 Vue.js 实现基于 Ajax 的表单提交错误验证操作
2017/06/30 PHP
PHP性能测试工具xhprof安装与使用方法详解
2018/04/29 PHP
php文件上传原理与实现方法详解
2019/12/20 PHP
PHP Trait功能与用法实例分析
2020/06/03 PHP
PHP7 字符串处理机制修改
2021/03/09 PHP
学习ExtJS form布局
2009/10/08 Javascript
jquery插件 cluetip 关键词注释
2010/01/12 Javascript
基于jquery的不规则矩形的排列实现代码
2012/04/16 Javascript
JavaScript中数组对象的那些自带方法介绍
2013/03/12 Javascript
IE8中动态创建script标签onload无效的解决方法
2014/12/22 Javascript
javascript 动态生成css代码的两种方法
2017/03/17 Javascript
jQuery+ajax实现修改密码验证功能实例详解
2017/07/06 jQuery
ReactNative之键盘Keyboard的弹出与消失示例
2017/07/11 Javascript
vue 项目build错误异常的解决方法
2019/04/22 Javascript
Vue 中使用富文本编译器wangEditor3的方法
2019/09/26 Javascript
手写Vue源码之数据劫持示例详解
2021/01/04 Vue.js
Python中实现字符串类型与字典类型相互转换的方法
2014/08/18 Python
pycharm安装图文教程
2017/05/02 Python
Python操作SQLite数据库的方法详解【导入,创建,游标,增删改查等】
2017/07/11 Python
Request的中断和ErrorHandler实例解析
2018/02/12 Python
对Python中DataFrame按照行遍历的方法
2018/04/08 Python
Python中利用xpath解析HTML的方法
2018/05/14 Python
python切片的步进、添加、连接简单操作示例
2019/07/11 Python
Python 中 sorted 如何自定义比较逻辑
2021/02/02 Python
css3弹性盒模型实例介绍
2013/05/27 HTML / CSS
H&M旗下高端女装品牌:& Other Stories
2018/05/07 全球购物
大学四年个人的自我评价
2014/02/26 职场文书
俄语专业毕业生求职信
2014/07/12 职场文书
上课睡觉检讨书300字
2014/11/18 职场文书
考研英语辞职信
2015/05/13 职场文书
创业计划书之酒店
2019/08/30 职场文书
详解Vue router路由
2021/11/20 Vue.js
一起来看看Vue的核心原理剖析
2022/03/24 Vue.js