我们的js引擎运行js 分为两步: 预解析 代码执行
js引擎预解析时,把所有的变量声明提升到当前作用域的最前面 不提升赋值操作
js引擎预解析时,把所有的函数声明提升到当前作用域的最前面 不调用函数
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script>
//1变量预解析
console.log(num);
var num = 10;
//js引擎预解析后对上面代码进行调整如下
// var num;
// console.log(num);
// num = 10;
fun();
var fun = function (){
console.log('Hello');
}
//js引擎预解析后对上面代码进行调整如下
// var fun;
// fun();
// fun = function () {
// console.log('Hello');
// }
//2函数预解析
func();
function func(){
console.log('Hi~');
}
//js引擎预解析后对上面代码进行调整如下
// function func(){
// console.log('Hi~');
// }
// func();
</script>
</head>
<body>
</body>
</html>
网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。
添加我为好友,拉您入交流群!
请使用微信扫一扫!