js作用域详解
2015-07-07 11:44
549 查看
// 作用域:(1)域:空间、范围、区域…… (2) 作用:读、写
script 全局变量、全局函数 自上而下
函数 由里到外
浏览器:
“JS解析器”
1)“找一些东西” :var function 参数
a = ...
所有的变量,在正式运行代码之前,都提前赋了一个值:未定义
fn1 = function fn1(){ alert(2); }
所有的函数,在正式运行代码之前,都是整个函数块
JS 的预解析
遇到重名的:只留一个
变量和函数重名了,就只留下函数
2)逐行解读代码:
表达式:= + - * / % ++ -- ! 参数……
表达式可以修改预解析的值!
例子一:
alert(a); //function a (){ alert(4); }
var a = 1;
alert(a);
function a (){ alert(2); }
alert(a);
var a = 3;
alert(a); // a = 3
function a (){ alert(4); }
alert(a);
例子二:
var a = 1;
function fn1(){
alert(a); //underfined
var a = 2;
}
fn1();
alert(a);
例子三:
var a = 1;
function fn1(){
alert(a);
a = 2; //局部变量可以修改全局变量
}
fn1();
alert(a);
script 全局变量、全局函数 自上而下
函数 由里到外
浏览器:
“JS解析器”
1)“找一些东西” :var function 参数
a = ...
所有的变量,在正式运行代码之前,都提前赋了一个值:未定义
fn1 = function fn1(){ alert(2); }
所有的函数,在正式运行代码之前,都是整个函数块
JS 的预解析
遇到重名的:只留一个
变量和函数重名了,就只留下函数
2)逐行解读代码:
表达式:= + - * / % ++ -- ! 参数……
表达式可以修改预解析的值!
例子一:
alert(a); //function a (){ alert(4); }
var a = 1;
alert(a);
function a (){ alert(2); }
alert(a);
var a = 3;
alert(a); // a = 3
function a (){ alert(4); }
alert(a);
例子二:
var a = 1;
function fn1(){
alert(a); //underfined
var a = 2;
}
fn1();
alert(a);
例子三:
var a = 1;
function fn1(){
alert(a);
a = 2; //局部变量可以修改全局变量
}
fn1();
alert(a);
相关文章推荐
- 让jsp页面不缓存验证码图片。
- javascript数组排序汇总
- [TypeScript] JSON对象转TypeScript对象范例
- 理解 JavaScript 中的 Function.prototype.bind
- Js组件的一些写法
- avalon.js实践 svg地图配置工具
- fastjson核心简要总结
- javascript编写贪吃蛇游戏
- javascript脚本加载
- js字符串替换所有的某一字符
- 牛角尖之js:点击复制
- Javascript编写2048小游戏
- js对象操作
- FastJson--阿里巴巴公司开源的速度最快的Json和对象转换工具
- jsp url传中文页面乱码
- 利用JavaScript脚本实现滚屏效果的方法
- JavaScript编写连连看小游戏
- javascript边角知识
- 使用JavaScript制作一个简单的计数器的方法
- 呼叫外部js文件并使用其内部方法