/*1.默认情况js代码从上往下执行 ----不严谨
2.预解析:js编译器在从上往下执行代码之前会把代码看一眼,在预解析的过程中会进行变量的提升
3.变量的提升:js在执行代码之前会把变量的声明提升到当前作用域的最顶端
* a.把var变量声明提前,只是声明提前,赋值还是在原地
* b.函数的声明也会提升
4.预解析的作用(意义):让函数在任何地方都可以被调用
5.如果一个变量声明的时候,没有var关键字,不参与作用域链,一定是全局变量,不参与预解析(尽量不用)
*/
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<script>
/*1.默认情况js代码从上往下执行 ----不严谨
2.预解析:js编译器在从上往下执行代码之前会把代码看一眼,在预解析的过程中会进行变量的提升
3.变量的提升:js在执行代码之前会把变量的声明提升到当前作用域的最顶端
* a.把var变量声明提前,只是声明提前,赋值还是在原地
* b.函数的声明也会提升
4.预解析的作用(意义):让函数在任何地方都可以被调用
5.如果一个变量声明的时候,没有var关键字,不参与作用域链,一定是全局变量,不参与预解析(尽量不用)
*/
//1.变量提升
console.log ( num );//undefined
var num = 10;
console.log ( num );//10
/*真实的预解析过程
var num
console.log ( num );
num = 10;
console.log ( num );
*/
//2.函数提升
fn();
function fn ( ) {
console.log ( "哈哈哈哈哈" );
}
/*真实的预解析过程
//函数声明提前
function fn ( ) {
console.log ( "哈哈哈哈哈" );
}
//调用语句还是在原地
fn();
*/
</script>
</body>
</html>