标签:
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>无标题文档</title>
<script>
/*
// 作用域:
// 域:空间、范围、区域……
// 作用:读、写
script 全局变量、全局函数
自上而下 。一个script就是一块,上下两块不同,单线程。上面存着的可以被下面访问的到。
函数
由里到外。不能从外到内,子级作用域找不到就去父级作用域,作用域链。
遇见函数调用,也会发生 预解析,逐行解读代码,相当于有一个小的仓库。
{}
浏览器:
“JS解析器”的步骤
1)首先“找一些东西” :var function 参数
a = ...
所有的变量,在正式运行代码之前,都提前赋了一个值:未定义
fn1 = function fn1(){ alert(2); }
所有的函数,在正式运行代码之前,都是整个函数块
JS 的预解析
遇到重名的:只留一个 无论上下
变量和函数重名了,就只留下函数,函数是一等公民,预解析两个函数重名的时候,下面
的代替上面的
2)接着逐行解读代码:
表达式:= + - * / % ++ -- ! 参数(参数传参也可以修改值)……
表达式可以修改预解析的值!
alert(a); // function a (){ alert(4); }
var a = 1;
alert(a); // 1
function a (){ alert(2); }
alert(a); // 1
var a = 3;
alert(a); // 3
function a (){ alert(4); }
alert(a); // 3
alert( typeof a );
// a(); 3()肯定是错误的 // 报错
*/
/*
var a = 1;
function fn1(){
alert(a); // undefined
//函数内部a和外面完全没有关系。先预解析a=……然后逐行解读遇见表达式再修改
var a = 2;
}
fn1();
alert(a); // 这次的a是全局范围的a所以找到1 1
var a = 1;
function fn1(){
alert(a); // 1 预解析之后执行时找到外面的作用域去
a = 2; 所以里面的表达式有能力去改外面的值修改的是外部的
}
fn1();
alert(a); // 2全局的a被修改为2了
*/
/*
var a = 1;
function fn1(a){
alert(a); // undefined 所以执行了就是undefined
//预解析时候找到了参数(参数就是一个局部变量)但是没有传参,就是undefined
a = 2; // 修改的是局部的,因为并没有去找外部作用域
}
fn1();
alert(a); // 1
var a = 1;
function fn1(a){ 函数调用,a传参,此时的a已经被全局的a赋值等于1
alert(a); // 1
a = 2; 修改的是局部的a,和外面全局的没关系
}
fn1(a);
alert(a); // 1
*/
</script>
</head>
<body>
</body>
</html>
标签:
原文地址:http://www.cnblogs.com/zhrn/p/4552308.html