浅谈JavaScript的函数及作用域
函数和作用域是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中没有函数重载的概念,函数通过名字确定唯一性,参数不同也被认为是相同的函数,后面的覆盖前面的。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望多多支持狼蚁SEO!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程