浅谈JavaScript的函数及作用域


Posted in Javascript onDecember 30, 2016

函数和作用域是JavaScript的重要组成部分,我们在使用JavaScript编写程序的过程中经常要用到这两部分内容,作为初学者,我经常有困惑,借助写此博文来巩固下之前学习的内容。

(一)JavaScript函数

JavaScript函数是指一个特定代码块,可能包含多条语句,可以通过名字来供其他语句调用以执行函数包含的代码语句。

1.JavaScript创建函数的方法有两种:

函数声明:

function funcDeclaration(){ return 'A is a function'; }

函数表达式:

var funExpression=function(){ return 'A is a function '; }

上述函数声明和函数表达式的区别(注明:翻译自:不同的方式来写一个函数)在:

JavaScript解析器中存在一种变量声明被提升(hosting)的机制,也就是说变量(函数)的声明会被提升到作用域的最前面,即使写代码的时候是写在最后面,也还是会被提升至最前面。

例如以下代码段:

alert(foo); // function foo() {}
alert(bar); // undefined
function foo() {}
var bar = function bar_fn() {};
alert(foo); // function foo() {}
alert(bar); // function bar_fn() {}

输出结果分别是function foo() {} 、undefined 、function foo() {} 和function bar_fn() {} 。

可以看到foo 的声明写在alert之后,仍然可以被正确调用,因为JavaScript解释器会将其提升到alert前面,而以函数表达式创建的函数bar则不享受此待遇。

所以,JavaScript 引擎执行以上代码的顺序可能是这样的:

  • 创建变量foo和 bar,并将它们都赋值为undefined。
  • 创建函数 foo 的函数体,并将其赋值给变量foo。
  • 执行前面的两个 alert。
  • 创建函数 bar_fn ,并将其赋值给 bar。
  • 执行后面的两个 alert。

2.函数的参数

在调用函数时,你可以向其传递值,这些值被称为参数。

function printName(name){
  console.log(name);
}
printName('Byron');
printName('Casper);

其中name是形参,'Byron'和'Casper'是实参。

说到函数的参数,我们不得不提到arguments。此处涉及的内容有点多,请看客们参考楼主之前转载的javascript arguments。

3.函数重载

重载是很多面向对象语言实现多态性的手段之一,在静态语言中确定一个函数的手段是靠方法签名--函数名+参数列表,也就是说相同名字的函数参数个数不同或者顺序不同都被认为是不同的函数,成为函数重载。

在JavaScript中没有函数重载的概念,函数通过名字确定唯一性,参数不同也被认为是相同的函数,后面的覆盖前面的。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
jquery中的sortable排序之后的保存状态的解决方法
Jan 28 Javascript
javascript中String类的subString()方法和slice()方法
May 24 Javascript
JavaScript实现班级随机点名小应用需求的具体分析
May 12 Javascript
Javascript添加监听与删除监听用法详解
Dec 19 Javascript
Jquery插件easyUi实现表单验证示例
Dec 15 Javascript
JavaScript中Window对象的属性及事件
Dec 25 Javascript
vue.js学习笔记:如何加载本地json文件
Jan 17 Javascript
JavaScript简单实现合并两个Json对象的方法示例
Oct 16 Javascript
React 无状态组件(Stateless Component) 与高阶组件
Aug 14 Javascript
Node.js实现一个HTTP服务器的方法示例
May 13 Javascript
javascript实现商品图片放大镜
Nov 28 Javascript
利用vue3+ts实现管理后台(增删改查)
Oct 30 Javascript
解析ajaxFileUpload 异步上传文件简单使用
Dec 30 #Javascript
JS实现的样式切换功能tableCSS实例
Dec 30 #Javascript
浅谈js script标签中的预解析
Dec 30 #Javascript
jQuery实现页面顶部下拉广告
Dec 30 #Javascript
jQuery Password Validation密码验证
Dec 30 #Javascript
JS编写函数实现对身份证号码最后一位的验证功能
Dec 29 #Javascript
EasyUI学习之Combobox下拉列表(1)
Dec 29 #Javascript
You might like
PHP的一个完整SMTP类(解决邮件服务器需要验证时的问题)
2006/10/09 PHP
PHP新手上路(三)
2006/10/09 PHP
使用php shell命令合并图片的代码
2011/06/23 PHP
CodeIgniter框架提示Disallowed Key Characters的解决办法
2014/04/21 PHP
php常用数学函数汇总
2014/11/21 PHP
隐性调用php程序的方法
2015/06/13 PHP
PHP获取当前相对于域名目录的方法
2015/06/26 PHP
PHP Beanstalkd消息队列的安装与使用方法实例详解
2020/02/21 PHP
Javascript remove 自定义数组删除方法
2009/10/20 Javascript
基于jquery的时间段实现代码
2012/08/02 Javascript
js控制滚动条缓慢滚动到顶部实现代码
2013/03/20 Javascript
jquery分页插件jquery.pagination.js实现无刷新分页
2016/04/01 Javascript
jQuery获取剪贴板内容的方法
2016/06/16 Javascript
yii form 表单提交之前JS在提交按钮的验证方法
2017/03/15 Javascript
Element input树型下拉框的实现代码
2018/12/21 Javascript
Bootstrap Paginator+PageHelper实现分页效果
2018/12/29 Javascript
30分钟精通React今年最劲爆的新特性——React Hooks
2019/03/11 Javascript
微信小程序开发之转发分享功能
2019/10/22 Javascript
用Python登录Gmail并发送Gmail邮件的教程
2015/04/17 Python
Python字符串切片操作知识详解
2016/03/28 Python
浅谈Python采集网页时正则表达式匹配换行符的问题
2018/12/20 Python
浅谈PySpark SQL 相关知识介绍
2019/06/14 Python
基于Django ORM、一对一、一对多、多对多的全面讲解
2019/07/26 Python
python爬取本站电子书信息并入库的实现代码
2020/01/20 Python
Python数据可视化实现漏斗图过程图解
2020/07/20 Python
世界上第一个创建了罩杯系统的美国内衣品牌:Maidenform
2019/03/23 全球购物
网络方面基础面试题
2012/11/16 面试题
医院护士求职自荐信格式
2013/09/21 职场文书
研究生自荐信
2013/10/09 职场文书
入党自荐书范文
2014/03/09 职场文书
小学生评语大全
2014/04/18 职场文书
骨干教师申报材料
2014/12/17 职场文书
上课睡觉万能检讨书
2015/02/17 职场文书
会计专业自荐信范文
2015/03/05 职场文书
八一建军节主持词
2015/07/01 职场文书
MySQL中一条SQL查询语句是如何执行的
2022/04/08 MySQL