JavaScript 函数的两种声明方式
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 函数的两种声明方式的更多相关文章
- JavaScript脚本的两种放置方式
JavaScript脚本的两种放置方式 1在body里用 script标签引用 2 直接写在<script></script>标签之中
- 第63天:json的两种声明方式
一. json 两种声明方式 1. 对象声明 var json = {width:100,height:100} 2. 数组声明 var man = [ // 数组的 js ...
- javascript中对象两种创建方式
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- javascript 函数的4种调用方式与 this(上下文)的指向
前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! javascript中作用域链和this(上下文)的指向是很容易混淆的,简单的说就是: 作用域链取决于函数 ...
- 第十篇----------javascript函数的三种定义方式及区别
javascript定义函数有3种方式: //3种函数定义方式,前两种常用 /** * 1,function 语句式 * 形式:句子 * 名称:有名 * 性质:静态 * 解析时机:优先解析 * 作用域 ...
- javascript 函数的几种声明函数以及应用环境
本页只列出常用的几种方式,当然还有比如new Function()以及下面三种的组合. 1.函数式声明 例子:function sum(a,b){ return a+b; }; 2.函数表达式声明(匿 ...
- javascript函数的4种调用方式
在javascript中一共有4种函数调用模式,分别是:方法调用模式.函数调用模式.构造函数调用模式和apply(call)调用模式,这4种模式的主要差异在于如何初始化关键参数this. 方法调用模式 ...
- js的数据类型、函数、流程控制及变量的四种声明方式
运算符 基本运算符 加 + 减 - 乘 * 除 / 取余 % 自增 ++ eg: 1++ 或 ++1 自减 -- eg: 1-- 或 --1 注:++或--写在前面表示优先级最高,先进行自增或者自减 ...
- JavaScript 函数的4种调用方法
JavaScript 函数有 4 种调用方式. 每种方式的不同方式在于 this 的初始化. 作为一个函数调用 function myFunction(a, b) { return a * b; } ...
随机推荐
- (转) 注意啦,笔记本是无线的,虚拟机上网方式莫用NAT,好难整。
有线网络 在有线网络的条件下,vmware的安装非常简单,上网方式几乎不用怎么设置(默认 NAT模式) 如果默认情况下不能上网,则按以下步骤尝试: ************************** ...
- CF750E New Year and Old Subsequence
讲道理好久没有做过题了.. 题目大意 给出长度为$n$的只含数字的串,有$q$个询问,每次询问一段区间,问最少删去多少个数才能变成只含2017子序列而不含2016子序列 吉爸爸好强啊.. 定义$a_{ ...
- bzoj1009矩阵快速面+kmp
其实kmp真的很次要,求长度为20的kmp感觉真的有点杀鸡用牛刀 这题思路相当明确:一看题就是数位dp,一看n的大小就是矩阵 矩阵的构造用m*m比较方便,本来想写1*m的矩阵乘m*m的,但是感觉想起来 ...
- TDD测试驱动开发
TDD测试驱动开发 一.概念 TDD故名思意就是用测试的方法驱动开发,简单说就是先写测试代码,再写开发代码.传统的方式是先写代码,再测试,它的开发方式与之正好相反. TDD是极限编程的一个最重要的设计 ...
- PS特效精粹
冲击有力的广告效果 神奇画笔功能 + 强大的图层样式 Photoshop中的三维特效
- Xpath基础语法学习
背景: 之所以学习Xpath,是因为在学习selenium定位页面元素,总是定位不到元素.为了更好的开展自动化测试,先学习下Xpath. 一:Xpath是什么. 1:Xpath是一门在XML文档中查找 ...
- #研发解决方案#分布式并行计算调度和管理系统Summoner
郑昀 创建于2015/11/10 最后更新于2015/11/12 关键词:佣金计算.定时任务.数据抽取.数据清洗.数据计算.Java.Redis.MySQL.Zookeeper.azkaban2.oo ...
- 用SQL语句将数据表中的数据保存为JSON格式
没有找到好的工具,只想到了拼字符串的方式,用 NVARCHAR(MAX) 可能有截断,不推荐使用,方法中使用了 FOR XML PATH('') 实现,有关其使用方法参考这里 表结构: SQL ...
- #iOS问题记录#动态Html加载本地CSS和JS文件
所谓动态Html,指代码中组合生成的html字符串: 若需要加载本地CSS,图片,JS文件,则, 1,需要文件的全路径: 2,需要"file:///"标志: 例如: //获取文件全 ...
- 一些linux包相关命令
针对centos 查看CentOS版本方法: lsb_release -a #result------------ LSB Version: :base-4.0-amd64:base-4.0-noar ...