标签:
<!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); // 1function a (){ alert(2); }alert(a); // 1var a = 3;alert(a); // 3function a (){ alert(4); }alert(a); // 3alert( typeof a );// a(); 3()肯定是错误的 // 报错*//*var a = 1;function fn1(){alert(a); // undefined//函数内部a和外面完全没有关系。先预解析a=……然后逐行解读遇见表达式再修改var a = 2;}fn1();alert(a); // 这次的a是全局范围的a所以找到1 1var 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//预解析时候找到了参数(参数就是一个局部变量)但是没有传参,就是undefineda = 2; // 修改的是局部的,因为并没有去找外部作用域}fn1();alert(a); // 1var a = 1;function fn1(a){ 函数调用,a传参,此时的a已经被全局的a赋值等于1alert(a); // 1a = 2; 修改的是局部的a,和外面全局的没关系}fn1(a);alert(a); // 1*/</script></head><body></body></html>
标签:
原文地址:http://www.cnblogs.com/zhrn/p/4552308.html