1.函数声明的方式

JavaScript声明函数有两种选择:函数声明法,表达式定义法。

  • 函数声明法

      function sum (num1 ,num2){
    return num1+num2
    }
  • 表达式定义法

      var sum = function(num1,num2){
    return num1+num2
    };

2.扒一扒两种函数声明的区别

解析器会率先读取函数声明(也就是说函数声明的优先级较高),并使其在执行任何代码之前可以访问(将函数声明提升到代码树顶部);至于函数表达式声明,则必须等到解析器执行到它所在的代码行,才会执行,无法自动提升。

同样的函数使用不同的定义方式,调用的时候会产生不同的效果。

// 函数声明法
var num = add(1, 2);
console.log(num);// 3 function add(a, b) {
return a + b
} // 函数表达式声明
var num = add(1, 2);
console.log(num);//Uncaught TypeError: undefined is not a function var add = function (a, b) {
return a + b
}

我们来看一看这两种声明方式到底对代码产生了怎样的影响。

首先看函数声明,由于发生了代码提升,实际的代码如下

// 函数声明法
function add(a, b) {
return a + b
}
var num = add(1, 2);
console.log(num);// 3 //function add(a, b) {
// return a + b
//}

再看表达式声明法,同样将变量add提升,add()函数调用的时候,只声明了变量add,却没有进行赋值。(此时的add变量是undefined)实际的代码如下。

// 函数表达式声明
var add;
var num = add(1, 2);
console.log(num);//Uncaught TypeError: undefined is not a function add = function (a, b) {
return a + b
}

3.关于变量提升和执行顺序

JavaScript是解释型语言,但它并不是逐行执行的。解析过程可以理解为两个阶段:一个是预处理阶段,JavaScript将脚本代码转换为字节码,该过程中将所有定义的变量提升到代码树顶端;第二个阶段,JavaScript解释器借助执行环境,把字节码生成机械码,该过程中才发生变量的赋值,并顺序执行。

console.log(a);
//Error:a is not defined ,直接报错,下面语句没法执行,以下结果为注释该句后结果
console.log(b) //undefined ,变量发生提升
var b="Test";
console.log(b);//Test

也就说JavaScript值执行第一句语句之前就已经将函数/变量声明预处理了

var b="Test" 相当于两个语句

var b;(undefined结果的来源,在执行第一句语句之前已经解析)

b=”Test”(这句是顺序执行的,在第二句之后执行)

这也是为什么我们可以在方法声明语句之前就调用方法的原因。

4.练一练

下面我们用一个经典的面试题目的一部分来对本篇文章进行总结

请问下面这段代码的执行结果是什么?

function Foo() {
getName = function () {
alert (1);
};
return this;
} Foo.getName = function () {
alert (2);
}; Foo.prototype.getName = function () {
alert (3);
}; var getName = function () {
alert (4);
}; function getName() {
alert (5);
} getName()

答案加载中...

答案加载中...

答案加载中...

答案加载中...

答案加载中...

答案加载中...

答案加载中...

答案加载中...

答案加载中...

答案加载中...

答案加载中...

答案加载中...

答案加载中...

答案加载中...

揭晓答案:

4

这里我主要讲解一下第二问中为什么是4,其他的在后续文章中进行说明。上面的代码实际上是这个样子滴

function Foo() {
getName = function () {
alert (1);
};
return this;
}
var getName;//只提升变量声明
function getName() { //提升函数声明,覆盖var的声明
alert (5);
}
Foo.getName = function () {
alert (2);
};
Foo.prototype.getName = function () {
alert (3);
};
getName = function () { //最终的赋值再次覆盖function getName声明
alert (4);
};
getName();//最终输出4

JavaScript 函数的两种声明方式的更多相关文章

  1. JavaScript脚本的两种放置方式

    JavaScript脚本的两种放置方式 1在body里用 script标签引用 2 直接写在<script></script>标签之中

  2. 第63天:json的两种声明方式

    一. json 两种声明方式 1. 对象声明   var  json = {width:100,height:100} 2. 数组声明   var  man = [        //  数组的 js ...

  3. javascript中对象两种创建方式

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. javascript 函数的4种调用方式与 this(上下文)的指向

    前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! javascript中作用域链和this(上下文)的指向是很容易混淆的,简单的说就是: 作用域链取决于函数 ...

  5. 第十篇----------javascript函数的三种定义方式及区别

    javascript定义函数有3种方式: //3种函数定义方式,前两种常用 /** * 1,function 语句式 * 形式:句子 * 名称:有名 * 性质:静态 * 解析时机:优先解析 * 作用域 ...

  6. javascript 函数的几种声明函数以及应用环境

    本页只列出常用的几种方式,当然还有比如new Function()以及下面三种的组合. 1.函数式声明 例子:function sum(a,b){ return a+b; }; 2.函数表达式声明(匿 ...

  7. javascript函数的4种调用方式

    在javascript中一共有4种函数调用模式,分别是:方法调用模式.函数调用模式.构造函数调用模式和apply(call)调用模式,这4种模式的主要差异在于如何初始化关键参数this. 方法调用模式 ...

  8. js的数据类型、函数、流程控制及变量的四种声明方式

    运算符 基本运算符 加 + 减 - 乘 * 除 / 取余 % 自增 ++ eg: 1++ 或 ++1 自减 -- eg: 1-- 或 --1 注:++或--写在前面表示优先级最高,先进行自增或者自减 ...

  9. JavaScript 函数的4种调用方法

    JavaScript 函数有 4 种调用方式. 每种方式的不同方式在于 this 的初始化. 作为一个函数调用 function myFunction(a, b) { return a * b; } ...

随机推荐

  1. 利用DNS Zone Transfers漏洞工具dnswalk

    利用DNS Zone Transfers漏洞工具dnswalk   DNS Zone Transfers(DNS区域传输)是指一台备用服务器使用来自主服务器的数据刷新自己的域(zone)数据库.当主服 ...

  2. 使用echarts开发电子屏数据展示页面

    背景 之前的项目因为要顾及体量问题,选用了highchart,没用上echarts:这次因为是本地部署电子屏幕的展示页,不需要考虑体量大小,直接用上了echarts:用起来觉得非常不错,特别是地图上非 ...

  3. Ubuntu14.04 64位机上安装cuda8.0 cudnn5.0操作步骤 - 网络资源是无限的

    查看Ubuntu14.04 64位上显卡信息,执行: lspci | grep -i vga lspci -v -s 01:00.0 nvidia-smi 第一条此命令可以显示一些显卡的相关信息:如果 ...

  4. java-并发-同步

    浏览以下内容前,请点击并阅读 声明 线程间的通信主要是通过访问以及对象引用字段,这种形式的通信非常高效,但是会产生两种可能的错误:线程干扰和内存一致性错误,反正这些错误的工具就是同步. 然而,同步可能 ...

  5. 【转】《从入门到精通云服务器》第四讲—DDOS攻击

    上周咱们深入分析了云服务器的配置问题,好了,现在手上有了云服务器之后,我们又不得不提它:DDOS攻击.这是所有运维者的心头痛,也是任何公司听闻后都将心惊胆战的强大对手.下面我们将用浅显易懂的方式讲述什 ...

  6. [VijosP1656]萌萌赶考 题解

    题目大意: 有一个地图,有障碍,不能重复经过一点(但起点可以),判断能否恰好在t时刻从起点到达终点. 思路: 一开始DFS一遍,30分,于是要有优化减枝.最重要的是从起点到终点的距离的奇偶性是与起点与 ...

  7. Python3.5 day4作业:对员工信息文件,实现增删改查操作。

    需求: 1.可进行模糊查询,语法至少支持下面3种: 1.select name,age from staff_table where age > 22 2.select  * from staf ...

  8. tomcat之Session的管理

    Session是由服务器端的应用服务器容器(如Tomcat.Jetty)存储的.下面分析一下Tomcat是如何管理Session的. 转自:tomcat架构分析 (Session管理) Tomcat中 ...

  9. Java 用LinkdeList实现52张扑克牌

    用LinkdeList实现52张扑克牌(不含大小王)的洗牌功能.提示:花色 ,和数字分别用数组存储. import java.util.LinkedList; import java.util.Ran ...

  10. $.each ---- 跳出当前的循环

    有些朋友可能会以为在jquery跳出循环可以直接使用continue和break了,但是使用之后没有效果,因为在jquery中没有这两条命令.后来上网查了下,得到了结果:return false;—— ...