返回顶部
首页 > 资讯 > 前端开发 > node.js >JavaScript作用域分为几类
  • 427
分享到

JavaScript作用域分为几类

2024-04-02 19:04:59 427人浏览 八月长安
摘要

本篇内容介绍了“javascript作用域分为几类”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

本篇内容介绍了“javascript作用域分为几类”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

JavaScript作用域分为全局作用域和局部作用域两类。变量在函数外定义为全局变量,全局变量有全局作用域,即网页中的所有脚本和函数均可使用;变量在函数内部声明为局部作用域,局部作用域一般只在固定的代码片段(例函数)内部可访问到。

教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

变量的作用域(scope),指的是变量在脚本代码中的可读、写的有效范围,也就是脚本代码中可以使用这个变量的区域。

变量的作用域主要分为全局作用域、局部作用域(也称函数作用域)两种。

相应作用域的变量分别称为全局变量、局部变量。全局变量声明在所有函数之外;局部变量是在函数体内声明的变量或者是函数的命名参数。

全局作用域(Global Scope)

变量在函数外定义为全局变量,全局变量有全局作用域:网页中的所有脚本和函数均可使用。

在代码中任何地方都能访问到的对象拥有全局作用域,一般来说以下几种情形拥有全局作用域:

 1、最外层函数和在最外层函数外面定义的变量拥有全局作用域

 2、所有末定义直接赋值的变量自动声明为拥有全局作用域

 3、所有window对象的属性拥有全局作用域

一般情况下,window对象的内置属性都拥有全局作用域,例如window.name、window.location、window.top等等。

局部作用域(Local Scope)

变量在函数内部声明为局部作用域。

和全局作用域相反,局部作用域一般只在固定的代码片段(例:函数)内部可访问到,最常见的例如函数内部,所有在一些地方也会看到有人把这种作用域称为函数作用域。

总之呢,当js解析器执行时,首先就会在执行环境里构建一个全局对象,我们定义的全局属性就是做为该对象的属性读取,在顶层代码中我们使用this关键字和window对象都可以访问到它。

而函数体中的局部变量只在函数执行时生成的调用对象中存在,函数执行完毕时局部变量即刻销毁。

因此在程序设计中我们需要考虑如何合理声明变量,这样既减小了不必要的内存开销,同时能很大程度地避免变量重复定义而覆盖先前定义的变量所造成的Debug麻烦。

说明:

变量的作用域跟声明方式有很密切的关系。使用 var 声明的变量的作用域有全局作用域和函数作用域;使用 let 和 const 声明的变量有全局作用域、局部作用域。

注意:严格意义的全局变量都属于 window 对象的属性,但 let 和 const 声明的变量并不属于 window 对象,所以它们并不是严格意义上的全局变量,在此仅仅从它们的作用域这个角度来说它们是全局变量的。

由于 var 支持变量提升,所以 var 变量的全局作用域是对整个页面的脚本代码有效;而 let 和 const 不支持变量提升,所以 let 和 const 变量的全局作用域指的是从声明语句开始到整个页面的脚本代码结束之间的整个区域,而声明语句之前的区域是没有效的。

同样,因为 var 支持变量提升,而 let 和 const 不支持变量提升,所以使用 var 声明的局部变量在整个函数中有效,而使用 let 和 const 声明的局部变量从声明语句开始到函数结束之间的区域有效。需要注意的是,如果局部变量和全局变量同名,则在函数作用域中,局部变量会履盖全局变量,即在函数体中起作用的是局部变量;在函数体外,全局变量起作用,局部变量无效,此时引用局部变量将出现语法错误。

示例:变量的作用域

     var v1 = "JavaScript"; //全局变量
     let v2 = "JScript"; //全局变量
     let v3 = "Script"; //全局变量
     scopeTest();    //调用函数
     function scopeTest(){
         var lv = "aaa"; //局部变量
         var v1 = "bbb"; //局部变量
         let v2 = "ccc"; //局部变量

         console.log("函数体内输出的lv = " + lv); //aaa
         console.log("函数体内输出的v1 = " + v1); //bbb
         console.log("函数体内输出的v2 = " + v2); //ccc
         console.log("函数体内输出的v3 = " + v3); //Script
         //v4为全局变量,赋值在后面,因而值为undefined
         console.log("函数体内输出的v4 = " + v4);
     }
     var v4 = "VBScript"; //全局变量
     console.log("函数体外输出的lv = " + lv); //① 报ReferenceError错误
     console.log("函数体外输出的v1 = " + v1); //JavaScript
     console.log("函数体外输出的v2 = " + v2); //JScript
     console.log("函数体外输出的v3 = " + v3); //Script
     console.log("函数体外输出的v3 = " + v4); //VBScript

上述脚本代码分别声明了 4 个全局变量、3 个局部变量。在 scopeTest 函数体外,变量 v1、v2、v3 和 v4 为全局变量;在 scopeTest 函数体内,lv、v2是全局变量。

我们看到,局部变量 v1 和 v2 与全局变量 v1 和 v2 同名,在 scopeTest 函数体内,局部变量 v1 和 v2 有效,因而在函数体这 2 个变量的输出结果分别为“bbb”和“ccc”;在函数体外,全局变量 v1 和 v2 有效,因而在函数体外,这 2 个变量的输出结果分别为“JavaScript”和“JScript”。

另外,全局变量 v3 和 v4 在函数体中没有被覆盖,因而输出的是全局变量的值,所以 v3 在函数体内和体外的输出结果都为“Script”,而 v4 变量的赋值在函数调用的后面,因而在函数体中的 v4 输出结果为“undefined”,而在函数体外的输出是在声明之后,所以结果为“VBScript”。lv 是局部变量,因而在函数体外访问会报“ReferenceError”错误。

上述代码在 Chrome 浏览器中运行后,打开浏览器的控制台,可以看到下图所示的输出结果

JavaScript作用域分为几类

上图 所示报第 18 行代码(即示例 ① 处注释的代码)中的 lv 没有定义的引用错误,这是因为 lv 变量为局部变量,离开函数后无效。将这行代码注释后再运行,此时打开浏览器控制台可看到下图所示结果

JavaScript作用域分为几类

“JavaScript作用域分为几类”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: JavaScript作用域分为几类

本文链接: https://lsjlt.com/news/73756.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaScript作用域分为几类
    本篇内容介绍了“JavaScript作用域分为几类”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • javascript内置函数分为哪几类
    这篇文章主要介绍了javascript内置函数分为哪几类的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇javascript内置函数分为哪几类文章都会有所收获,下面我们一起来看看...
    99+
    2024-04-02
  • javascript运算符可分为哪几类
    这篇文章给大家分享的是有关javascript运算符可分为哪几类的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 javascript运算符可分为:1、...
    99+
    2024-04-02
  • 域名服务器分为哪几种类型
    域名服务器分为以下几种类型:1. 主域名服务器(Master DNS Server):主要负责管理一个域名的解析记录,通常由域名所有...
    99+
    2023-06-06
    域名服务器 服务器 域名
  • 常见的顶级域名分为哪几类
    常见的顶级域名分为以下几类:1. 国家顶级域名(ccTLD):代表国家或地区的域名,如.cn代表中国,.us代表美国,.uk代表英国...
    99+
    2023-06-10
    顶级域名 域名
  • linux用户分为哪几类
    这篇文章主要介绍“linux用户分为哪几类”,在日常操作中,相信很多人在linux用户分为哪几类问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”linux用户分为哪几类”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-06-29
  • 如何分析javascript作用域和作用域链
    如何分析javascript作用域和作用域链,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、javascript的作用域1、全局作用域1、最外层函数和最外层函...
    99+
    2023-06-28
  • 域名可以分哪几类
    这篇文章主要讲解了“域名可以分哪几类”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“域名可以分哪几类”吧!易打类易打是这类域名最突出的特点。或许此类域名不好记也不顺口,但是针对不熟悉电脑键盘的...
    99+
    2023-06-06
  • JavaScript作用域实例分析
    这篇文章主要讲解了“JavaScript作用域实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript作用域实例分析”吧!  ...
    99+
    2024-04-02
  • JavaScript作用域和作用域链的示例分析
    这篇文章给大家分享的是有关JavaScript作用域和作用域链的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。作用域(Scope)1. 什么是作用域作用域是在运行时代码中...
    99+
    2024-04-02
  • 域名的分类有哪几种
    域名的分类可以从不同角度进行划分,以下是常见的几种分类:1. 根据顶级域名(TLD)分类:例如.com、.cn、.net等。2. 根...
    99+
    2023-06-06
    域名的分类 域名
  • MySQL字段类型分为哪几类
    这篇文章主要介绍“MySQL字段类型分为哪几类”,在日常操作中,相信很多人在MySQL字段类型分为哪几类问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL字段类型分为哪...
    99+
    2024-04-02
  • html标记分为哪几类
    这篇文章主要讲解了“html标记分为哪几类”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“html标记分为哪几类”吧! 单标记:标记只有一个,不是修饰内容的...
    99+
    2024-04-02
  • html5标记分为哪几类
    本篇内容介绍了“html5标记分为哪几类”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • php错误分为哪几类
    本篇内容介绍了“php错误分为哪几类”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!php错误一般分为三类:1、语法错误,是在编程中最容易碰到...
    99+
    2023-06-20
  • 编码器分为哪几类
    这篇文章主要介绍“编码器分为哪几类”,在日常操作中,相信很多人在编码器分为哪几类问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”编码器分为哪几类”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!编码器是将信号(...
    99+
    2023-06-26
  • 小程序分为哪几类
    本文小编为大家详细介绍“小程序分为哪几类”,内容详细,步骤清晰,细节处理妥当,希望这篇“小程序分为哪几类”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、 模板小程序概述:功能、样式固定,需要搭建在本地使用,没有...
    99+
    2023-06-27
  • JavaScript作用域的示例分析
    这篇文章给大家分享的是有关JavaScript作用域的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。作用域作用域(Scope)简单的说就是变量,函数和对象定义后其可用的范围。console.log(a){...
    99+
    2023-06-25
  • oracle分区表可以分为几类
    这篇文章主要讲解了“oracle分区表可以分为几类”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“oracle分区表可以分为几类”吧!Oracle分区表分为四...
    99+
    2024-04-02
  • Javascript之作用域、作用域链、闭包的示例分析
    这篇文章主要介绍Javascript之作用域、作用域链、闭包的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!什么是作用域?作用域是一种规则,在代码编译阶段就确定了,规定了变量...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作