zoukankan      html  css  js  c++  java
  • js 函数 作用域 全局作用域 局部作用域 闭包

    一个变量没有声明但调用 直接报错,声明没有赋值会显示未定义。

    作用域

    作用域(scope):一条数据可以在哪个范围中使用。 通常来说,一段程序代码中所用到的数据并不总是有效/可用的,而限定这个数据的可用性的代码范围就是这个名字的作用域。作用域的使用提高了程序逻辑的局部性,增强程序的可靠性,减少名字冲突。

    变量(数据)js中,变量的作用域有两中,一种是全局作用域(全局变量) ,一种局部作用域(局部变量),一个变量是全局变量还是局部变量,主要看变量声明的位置。声明在函数内部,就是这个函数(function)的局部变量。(在js的ECMAScript5.1中只有函数才会产生作用域)?

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

    function fn(){

    window.nub = 100;

    }

    fn();

    alert(nub);

    加在window上边的内容作用域 属于全局的,属于window的属性,可以不用写window,直接写属性名就行 / / function fn(){ nub = 100; } fn(); alert(nub);

    变量如果不加声明,就默认认为是window的内容,作用域变成全局了

    1 加在window上的内容作用域属于全局的。 属于window的属性,可以不用写window,直接写属性名即可

    2 变量若不加声明,就默认为window的内容,作用域变成全局。

    3 没有声明在如何函数内部的变量(全局),就是全局变量在全局的任何地方就可以调用和修改,尽量不要使用全局变量,会早成全局污染 全局命名空间污染 在程序中经常需要引用一些库,如C++编译系统提供的标准库、由第三方软件开发商提供的开发库或者用户自己开发的库等。如果在这些库中含有与程序中定义的全局实体同名的实体,或者不同的库之间有同名的实体,则在编译时都会出现名字冲突,这就称为全局命名空间污染 (命名冲突)

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

    域解析

    域解析:浏览器每读到一个script标签,先不执行任何代码会先把这个代码快速的浏览一遍,然后从中挑出 var和 function 两个关键字。

    var: 域解析遇到 var就把var连同它后边的名字一块提到所在的script(或function)的最前面,域解析完成之后,在从上往下一行一行执行代码,如果遇见就= 赋值

    function: 预解析遇到function,就把整个函数提到script(或function)的最前面。(跟在var的后边预解析先解析var 在解析 function)function的优先级高于var

    作用域链

    [[Scopes]] : 作用域 当我们声明一个函数的时候,同时该函数就会创建一个属性这个属性是[Scopes],我们在这个函数中 声明的变量都会被存入这个函数的[[Scopes]]属性中 变量与函数的查找规则: 当我们调用一条数据的时候,js首先会在当前作用域中进行查找,如果找不到,就向上找到父级的作用域,如果在父级的作用域中也找不到,就继续向上查找,直到window的作用域。如果在window中也找不到,就报错了

    闭包

    里面可以访问外边的,但是外边不能访问里边的。 闭包: 形式函数中套了一个函数,内层函数可以访问外层函数中的局部数据。

  • 相关阅读:
    Feature的开发和部署
    MOSS 2007应用如何修改上传文件大小及类型的限制
    学习Ajax的优秀网站
    Office SharePoint 权限开发
    Asp.net操作Excel汇总
    如何取到MOSS列表中item的链接
    解决MOSS、SharePoint的未知错误
    Ajax 之 XMLHttpRequest
    C#中从资源文件里加载文件
    linux 技巧:使用 screen 管理你的远程会话 [linux]
  • 原文地址:https://www.cnblogs.com/YinWeiBlog/p/7430971.html
Copyright © 2011-2022 走看看