1、函数本身的作用域
因为其中,console.log在function内部,var a =1,传入x,但是x和f不是一起的,所以,f改变的a无法改变x中的a。
<!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>
var a = 1;
var x = function ()
{
var a =2;//因为在同一个函数里面所以有用
console.log(a);
};
function f()
{
var a = 2;//因为不在同一个函数里面,没用
x();
}
f() // 1
</script>
</head>
<body>
</body>
</html>