关于JS函数的问题

关于JS函数的问题

  • 主要讨论函数声明式和函数表达式的区别:
  1. 先看两个例子:
例子1a();//我是声明式函数
function a(){
	console.log('我是声明式函数')
}
例子2a();//a is not a function
var a = function (){
	console.log('我是赋值型函数(即函数表达式)')
}
  • 问题:为什么执行会结果不一样?为什么例子2的执行结果不是“a is not defined”?
  • 答:由于JS的执行顺序,会对函数声明和变量声明进行预编译,声明式定义的函数会函数提升(类似变量提升)。而赋值型函数(即函数表达式)本质是声明一个变量(在a执行前,a由于变量提升而完成变量声明)然后将一个匿名函数赋值给它。
  1. 再看两个例子:
例子1function a(){
	console.log('我是声明式函数')
}
var a = function (){
	console.log('我是赋值型函数')
}
a();//我是赋值型函数
例子2var a = function (){
	console.log('我是赋值型函数')
}
function a(){
	console.log('我是声明式函数')
}
a();//我是赋值型函数
  • 问:例子中的声明式函数和赋值型函数调换了顺序,为什么执行结果依旧相同?
  • 答:因为声明式函数在预编译阶段已经声明过了(因此声明式函数随意放置,都会优先声明,不影响JS执行结果),而变量a需要JS执行到该赋值语句时才会赋值函数,相当于赋值型函数替换掉了声明式a函数。
    3、还有一个很奇怪的例子(不是很懂)
function a(){
	console.log('我是声明式函数a')
}
var b = function a(){
	console.log('我是函数表达式b')
}
console.log(b)//function a(){console.log('我是函数表达式b')
a();//'我是声明式函数a'
b();//'我是函数表达式b'
}
  • 两个函数在不同的变量上,但很费解的是变量b打印出来形式跟函数声明式一样。一个是预编译是声明的,一个是在JS执行时声明的,但却占据不同的存储空间,后者不会替换前者。暂时不是很理解为什么,等以后了解清楚再作修改。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值