作用域

Posted tis100204

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了作用域相关的知识,希望对你有一定的参考价值。

1、梳理知识点
循环嵌套完成图形题  
函数定义 : function fn(){}
函数调用 : 函数名()
函数参数 : 
    形参 和 实际参数
函数返回值 : return  
 
2、变量的作用域
作用域 : 作用范围
 
全局变量 :
    作用范围 : 从程序开始到程序结束   即在script标签内
    在函数体外部定义的变量或内部没有var的变量就是全局变量
 
局部变量 :
    作用范围 : 函数体,从函数开始到函数调用结束后  函数调用结束后 局部变量自动销毁 
    在函数体内部通过var明确定义的变量 或 形参
函数体中的变量如果操作的是全局变量,该变量就是全局的,如果操作的是局部变量,该变量就是局部的 
 
问题来了 : 如何确定函数体中的变量操作的是局部的还是全局的???
 
作用域链 :  函数体中在改变某个变量的值时, 都会向上查找 ,如果查找到局部变量 , 操作的就是局部变量 ,如果没有找到局部变量,继续向上(函数体外部)查找,如果查找到 ,操作的就是全局变量,如果函数内部和外部都没有查找到 ,判断这个变量定义是否var 有var 就是局部变量 ,没有var 就是全局变量
为了防止全局变量污染 尽量避免出现全局变量
 
3、变量提升 
在函数体内部定义的变量  会将变量提升到函数的最顶端  只提升声明,但不赋值
function fn(){
    alert(a);
    var a = 10;
}
fn();
 
变量提升后
function fn(){
    var a;
    alert(a);
    a = 10;
}
 
 
4、js解析器(扩展)
浏览器内部有个专门解析js程序的地方,这个空间就叫做js解析器
解读js程序 有两个步骤:
   1、预解析   找一些东西  var  function 
        找到了var  就意味着找到了一个变量  会提前为这个变量赋予一个值 undefined
        找到了function 就意味着找到了一个函数  会提前为这个函数名赋予一个值 这个值就是函数块本身 
        找到了两个function,如果函数重名  后一个会覆盖前一个
        如果找到的变量和函数重名  保留函数
   2、逐行解读代码  如果遇到表达式 改变了变量的值  那么 预解析时 仓库中变量的值也会随着发送变化
 
5、函数的递归调用
递归 : 函数自己调用自己
缺点 : 消耗性能
递归本质 : 实现循环
 
 
6、函数的实参副本(扩展)
arguments
1、必须出现在函数体中 
2、含有一个length属性  代表实参个数
3、取出arguments中的实参  arguments[下标]  下标从0开始  最大下标:  arguments.length-1
 
7、函数和事件的关系
事件 : 对页面上某个元素的操作
事件三要素 : 
    事件源   名词   页面上的某个元素 
    事件     动作   
    事件处理程序    函数
单击按钮 : 
    oBtn.onclick = function(){  ....  }
常见事件 : 
    鼠标事件 : 
        onclick 单击 
        ondblclick 双击
        onmouseover 鼠标滑过
        onmouseout  鼠标离开
 
        onmouseenter 鼠标滑过
        onmouseleave 鼠标离开
 
        onmousedown 按下
        onmouseup  抬起
        onmousemove 移动
 
    表单事件(针对表单操作) :
        onsubmit  表单提交
        onfocus  获取焦点
        onblur   失去焦点
        onchange  改变(一般用于 下拉列表)
 
    键盘 :
        onkeyup  抬起
        onkeydown  按下
        onkeypress 按下+抬起
 
    页面事件 :
        onload 页面加载事件      
        onload事件处理程序中的代码 会等到页面所有内容(css img html 等) 全部加载完成后执行       
 
8、js对元素的操作
要做事 先找人
提前找到要操作的元素 obj
 
样式操作 :
    obj.style.样式 = 值  设置某个元素的样式     注意 :小驼峰的写法  fontSize  
 
属性操作(标签的属性  <img src=‘‘>) :
    obj.属性 = 值     obj.src = ""
 
内容操作 :
    普通标签内容 :
        obj.innerHTML = ""  设置内容
    表单内容 :
        obj.value = ""  设置  

以上是关于作用域的主要内容,如果未能解决你的问题,请参考以下文章

0140 JavaScript作用域:概述全局作用域函数作用域块级作用域

作用域和闭包作用域和作用域链

js 静态作用域和动态作用域

JavaScript 作用域作用域链变量提升

JavaScript 作用域作用域链变量提升

js 函数作用域, 块级作用域和词法作用域