浅析javascript中函数声明和函数表达式的区别
作者:hebedich 时间:2024-05-09 10:33:14
javascript中声明函数的方法有两种:函数声明式和函数表达式.
区别如下:
1).以函数声明的方法定义的函数,函数名是必须的,而函数表达式的函数名是可选的.
2).以函数声明的方法定义的函数,函数可以在函数声明之前调用,而函数表达式的函数只能在声明之后调用.
3).以函数声明的方法定义的函数并不是真正的声明,它们仅仅可以出现在全局中,或者嵌套在其他的函数中,但是它们不能出现在循环,条件或者try/catch/finally中,而
函数表达式可以在任何地方声明.
下面分别用两种方法定义函数:
//函数声明式
function greeting(){
console.log("hello world");
}
//函数表达式
var greeting = function(){
console.log("hello world");
}
下面一个有趣的javascript:
function f() { console.log('I am outside!'); }
(function () {
if(false) {
// 重复声明一次函数f
function f() { console.log('I am inside!'); }
}
f();
}());
会输出什么呢?第一反应应该是"I am outside"吧. 结果在chrome中输出"I am inside",IE11直接报错,firefox低一点的版本输出"I am outside"...
chrome输出的结果很明确的反应了用函数声明式声明的函数的特点--函数在声明之前就可以调用.
IE报错显示缺少对象,因为函数声明在了条件里,违背了函数声明式的原则.
函数表达式的作用域:
如果函数表达式声明的函数有函数名,那么这个函数名就相当于这个函数的一个局部变量,只能在函数内部调用,举个栗子:
var f = function fact(x) {
if (x <= 1)
return 1;
else
return x*fact(x-1);
};
alert(fact()); // Uncaught ReferenceError: fact is not defined
fact()在函数内部可以调用,在函数外部调用就会报错:fact未定义
标签:javascript,函数声明,函数表达式
0
投稿
猜你喜欢
Python的Django框架中TEMPLATES项的设置教程
2022-09-23 03:16:09
Oracle中PL/SQL复合数据类型
2024-01-22 07:17:47
asp生成不需要数据库的中奖码
2008-07-18 12:31:00
Python采集王者皮肤图片实战示例
2021-08-02 12:09:23
golang validator库参数校验实用技巧干货
2024-04-23 09:38:17
Python进阶学习修改闭包内使用的外部变量
2023-04-09 01:23:04
详解用python -m http.server搭一个简易的本地局域网
2023-09-29 13:03:34
Vue.js实现一个todo-list的上移下移删除功能
2024-04-26 17:38:32
mysql 5.1版本修改密码及远程登录mysql数据库的方法
2024-01-17 15:38:02
MySQL不支持INTERSECT和MINUS及其替代方法
2024-01-14 15:09:11
使用Python绘制空气质量日历图
2023-06-20 12:19:21
原生JS与jQuery编写简单选项卡
2024-04-30 09:52:52
python使用matplotlib绘制折线图
2021-08-23 05:12:53
Python assert语句的简单使用示例
2023-06-12 16:38:58
php+mysql删除指定编号员工信息的方法
2024-06-05 09:40:28
微信小程序控制台提示warning:Now you can provide attr "wx:key" for a "wx:for" to improve performance解决方法
2024-04-18 09:42:40
Python打包工具PyInstaller的安装与pycharm配置支持PyInstaller详细方法
2022-05-20 06:36:55
简述php环境搭建与配置
2023-11-15 09:08:28
1秒50万字!js实现关键词匹配
2024-05-02 16:18:04
pandas中apply和transform方法的性能比较及区别介绍
2023-07-18 22:23:40