码迷,mamicode.com
首页 > 编程语言 > 详细

JavaScript中---作用域

时间:2016-12-05 23:11:05      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:改变   哪些   渲染   同名   替代   解析   代码   使用   工作原理   

作用域:
变量还有函数作用的范围。
浏览器的内核主要有两大功能,一个是渲染页面,另一个就是我们的JavaScript的解释器了。

我们主要来说说JavaScript解释器,在解析时是怎么样的工作原理。

在解析的时候,首先会发生预解析,就是说不会直接一行一行去执行我们所写的代码,它会先去找有哪些声明的变量,遇见函数体的时候会把函数放到最上面的位置,当变量名和函数名重名的时候函数会替代变量声明。
在解析的时候碰到的是个函数体,那么会预先处理函数体中的变量或者函数,知道有哪些声明的事项。
如果是变量,那么在函数体中调用变量时,会取函数体当中的变量,如果函数体中没有,则找外层变量

函数预解析:
  会将函数提到顶部
变量预解析:
  会内部事先知道是否有该变量,但不会改变解析位置

  当预解析时,变量和函数出现同名时,函数会替代掉变量,同一个命名只会存在一个


全局作用域 - 在任何地方都能访问
  函数外定义的变量拥有全局作用域
  不使用var定义的变量拥有全局作用域
  所有window对象上的属性拥有全局作用域
局部作用域 - 只能在函数内部访问
  使用var在函数内部定义的变量拥有局部作用域


全局:在任何地方都能调用
局部:只在当前作用范围(功能体)能调用

 1 <script>
 2     var a = 10;// 全局
 3     function fn() {
 4         console.log(a);//undefined
 5         var a = 5;// 局部
 6         console.log(a);//5
 7     }
 8     fn();
 9             
10 </script>

闭包的概念
  函数嵌套函数,内层函数可以访问外层函数中的变量

 1 <script>
 2     function fn1() {
 3         var a = 1;
 4         function fn2() {
 5         a++;
 6         console.log(a);
       return a;
7 } 8 fn2(); 9 } 10 fn1(); 11 </script>

闭包的做大用处有两个:

一个是在函数体外部读取i内部的变量,另一个就是让这些变量始终保存在内存中。

JavaScript中---作用域

标签:改变   哪些   渲染   同名   替代   解析   代码   使用   工作原理   

原文地址:http://www.cnblogs.com/exhuasted/p/6135409.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!