博客
关于我
变量的声明提前和函数的声明提前 全局作用域和函数作用域的定义和释义
阅读量:651 次
发布时间:2019-03-15

本文共 759 字,大约阅读时间需要 2 分钟。

window全局对象

全局作用域

全局作用域是直接编写在<script>标签中的JavaScript代码的运行环境。全局作用域中的变量都是全局变量,可以在页面的任意部分访问。页面启动时,全局作用域创建,页面关闭时,全局作用域销毁。

window对象

window是全局作用域中的一个对象,代表浏览器窗口,是浏览器创建的。我们可以直接使用window对象。全局作用域中创建的变量会成为window对象的属性。

变量的声明提前

变量的声明会提前,无论变量声明的位置在哪里,声明都会在所有代码执行前完成。

  • 例如var a = 123;无论a的声明位置在哪里,都会在所有代码执行前被声明。
  • 如果不使用var声明变量,如a = 123;,则变量会被声明,但不会提前声明。

函数的声明提前

函数有两种定义方式:

  • 函数表达式function hanshu1() {})会在所有代码执行前被定义,可以提前调用。
  • **当使用var定义函数(如var hanshu2 = function() {})时,函数不会提前声明。
  • 函数定义域

    每次调用函数时,函数作用域都会创建并销毁。在函数作用域中,变量的查找会依次从自身作用域向上查找,最终寻找到全局变量。

    注意

    • 函数可以嵌套,内部函数可以访问外部函数的变量。
    • 在函数作用域中未定义的变量会变成全局变量。

    实用小贴士

    • 使用window对象访问全局变量:window.a
    • 函数定义域中的变量查找遵循“ closure principle”(闭包原理),函数内的变量会在函数外保留,但不能直接修改外部变量,除非明确声明。
    • 使用evalnew Function时,要特别注意变量的声明和作用域。

    通过以上理解,可以更好地掌握JavaScript中变量和函数的作用域原理,避免变量污染问题。

    转载地址:http://fabmz.baihongyu.com/

    你可能感兴趣的文章
    Openlayers中将某个feature置于最上层
    查看>>
    Openlayers中点击地图获取坐标并输出
    查看>>
    Openlayers中设置定时绘制和清理直线图层
    查看>>
    Openlayers图文版实战,vue项目从0到1做基础配置
    查看>>
    OpenLayers学习三:地图旋转及地图跳转到某一点的方式(以类为接口)
    查看>>
    Openlayers实战:modifystart、modifyend互动示例
    查看>>
    Openlayers实战:判断共享单车是否在电子围栏内
    查看>>
    Openlayers实战:加载Bing地图
    查看>>
    Openlayers实战:绘制图形,导出geojson文件
    查看>>
    Openlayers实战:绘制图形,导出KML文件
    查看>>
    Openlayers实战:绘制多边形,导出CSV文件
    查看>>
    Openlayers实战:绘制带箭头的线
    查看>>
    Openlayers实战:自定义放大缩小,显示zoom等级
    查看>>
    Openlayers实战:自定义版权属性信息
    查看>>
    Openlayers实战:输入WKT数据,输出GML、Polyline、GeoJSON格式数据
    查看>>
    Openlayers实战:选择feature,列表滑动,定位到相应的列表位置
    查看>>
    Openlayers实战:非4326,3857的投影
    查看>>
    Openlayers高级交互(1/20): 控制功能综合展示(版权、坐标显示、放缩、比例尺、测量等)
    查看>>
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>
    Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
    查看>>