博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
javascript,函数声明和函数表达式
阅读量:5314 次
发布时间:2019-06-14

本文共 723 字,大约阅读时间需要 2 分钟。

在javascript中有两种函数的定义法:函数声明,函数表达式。

函数声明:

function doSomthing(){    return "hello";  }

函数表达式:

var f1 = function doSomthing(){    return "hello";};

函数声明和函数表达式在执行效果上是等价的,但是解析器在向执行环境中加载数据对函数声明和函数表达式的处理确实不同的。

1.对于函数声明

  在代码开始执行之前,解析器通过函数声明提升(function declaration hoisting)的过程,读取并将函数声明添加到了执行环境中并放置于源代码树的顶部。

  因此,即使声明函数在调用代码之后,代码也能顺利执行。

alert(doSomthing());function doSomthing(){    return "hello";    }//执行OK

2.对于函数表达式

  在一个初始化语句中生成一个函数,并用一个变量引用该函数。在这种情况下,不会经历函数声明提升过程,在执行到函数表达式所在语句之前,引用函数的变量是不会保存有对函数的引用。

 下面的代码解析器直接报错:"undefined is not a function",不会执行到函数表达式。

alert(f1());var f1 = function doSomthing(){    return "hello";    };

 

总结:

函数声明:定义和执行顺序无关。

函数表达式:先定义后执行。

 

 

 

转载于:https://www.cnblogs.com/kongxianghai/archive/2013/03/20/2970649.html

你可能感兴趣的文章
js链式调用
查看>>
The connection to adb is down, and a severe error has occured
查看>>
数字统计
查看>>
20180620小测
查看>>
iptables设置规则
查看>>
聊聊setTimeout和setInterval线程
查看>>
计算机经典书箱
查看>>
随机给出三十道四则运算题目
查看>>
vmware 克隆后Linux没有eth网卡只有lo
查看>>
[snmp++]读取cisco路由交换机信息[一] - 环境搭建
查看>>
文本字符集转换
查看>>
CSS3弹性伸缩布局(一)——box布局
查看>>
设计模式 - Mediator
查看>>
数据结构小总结(成都磨子桥技工学校数据结构前12题)
查看>>
css2--collapse
查看>>
.net post xml 数据
查看>>
How to change the text color in the terminal
查看>>
Eclipse启动时布局不合理调整
查看>>
转: telnet命令学习
查看>>
GIT
查看>>