if判断中的重复函数声明
if(condition){
function sayHi(){
alert("Hi!");
}
} else {
function sayHi(){
alert("Yo!");
}
}
浏览器JavaScript引擎修正错误差异:大多浏览器会返回第二个声明,忽略condition;FF则会在condition为true时返回第一个声明。
使用函数表达式可解决并实现:
if判断 函数表达式
var sayHi;
if(condition){
sayHi = function(){
alert("Hi!");
}
} else {
sayHi = function(){
alert("Yo!");
}
}
//下面函数的知识点 预编译,变量申明,函数提升和作用域,
var a = 0;
function test1(){
alert(a);
var a=1;
}
test1(); //undefined
//用var声明的变量在整个作用域内都有效,代码等同于
var a = 0;
function test1(){
var a;
alert(a);
a=1;
}
test1(); //undefined
var a = 1;
var a;
alert(a);
//js从来不会告诉你是否多次声明了一个变量,遇到这种情况他只会对后续的代码视而不见(不过他会执行后续声明中的变量初始化)如下:
var b = 1;
var b = 2;
alert(b);
//函数声明大括号后不能添加()
function test1(){
}();
//表达式可以添加()
var test1 = function(){
}();
//给函数声明加一对圆括号也可以把函数声明转换为表达式
(function(){
//块级作用域
})();