javascript - 看到函数声明这块有个函数不是很理解
问题描述
这是js高程上面的一个例子看到函数声明有一个代码
if(condition){ function sayHi(){alert(’hi’) }}else{ function sayHi(){alert(’Yo’) }}
说是这段代码无效语法,大多数浏览器会返回第二个声明,firefox会返回第一个声明,这是为什么?如果改成函数表达式形式的就可以了,这又是为什么?
var sayHi;if(condition){ sayHi=function(){alert(’Hi’) }}else{ sayHi=function(){alert(’Yo!’) }}
问题解答
回答1:因为第一个是函数声明, 但是一般不会放在if-else中声明函数
第二个是把匿名函数赋值给变量 ,不存在提升之类的
回答2:直接写function xxx(){} 会导致声明提前,如果有两个同名的这样的函数,相当于在顶部执行了两次var xxx,所以无效
回答3:和什么声明前置没有关系,高程第三部那时候JavaScript规范还都是ES5,浏览器还没有实现块级作用域(ES2016+),作用域级别只是函数级别的。所以你写的
if(condition){ function sayHi(){alert(’hi’) }}else{ function sayHi(){alert(’Yo’) }}
和写的
function sayHi(){ alert(’hi’)}function sayHi(){ alert(’Yo’)}
没有本质区别
回答4:js是有声明提前的!!!function会在声明时直接提到作用域顶端。if中不存在作用域,所以两个function是一个作用域,第二个会替掉第一个。! 而你第二段代码,先声明了变量sayhi,在if判断后才对sayhi进行赋值,
相关文章:
1. mysql - sql 语句更改表结构,添加多个列,怎么写?2. javascript - vue中父组件向子组件传递Object时,如何避免TypeError?3. angular.js - 在移动端web上如何解决输入法挡住文本框问题?4. javascript - 怎么设计项目的返回码,让不同的返回码代表不同的含义?5. javascript - svg小白,想要在svg里面插入图片6. android-studio - Android Studio 2.2 beta2 更新后强制将 Gradle 版本升级为 2.14.1,有没有遇到同样情况的?7. python - 关于django 模板中循环列表8. css3 怎么实现锯齿状的剪纸效果(如图)9. html5 - 如何利用Canvas技术制作出上下跳动的音乐谱10. mac连接阿里云docker集群,已经卡了2天了,求问?