返回顶部
首页 > 资讯 > 前端开发 > VUE >怎么理解JS另类的作用域
  • 579
分享到

怎么理解JS另类的作用域

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

本篇内容主要讲解“怎么理解js另类的作用域”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解JS另类的作用域”吧!1.变量的作用域稍微有些编程背景的都知道,

本篇内容主要讲解“怎么理解js另类的作用域”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解JS另类的作用域”吧!

1.变量的作用域

稍微有些编程背景的都知道,变量的作用域分为两种: 全局变量 和 局部变量 。

javascript是一门 弱类型语言 。所有的变量声明都是通过var来接收,如

var num = 1; var str = “string”; var flag = true;

看似是一个非常省事的机制,但是也有让人头疼的时候,一些隐式的类型转换经常会把搞晕,这里不做展开,后面有时间可以单独开一篇详谈。先看看全局变量和局部变量:

var g = "global"; function f(){ var l = "local"; }

怎么理解JS另类的作用域

注意 : 1. 如果在函数f()中将去掉var声明,则变量l就会从局部变量升级为全局变量。

2. 局部变量的优先级高于同名的全局变量 。如果在函数f()中声明一个局部变量也为g,则全局变量就会被局部变量覆盖

怎么理解JS另类的作用域

2.作用域和声明提前

看到Javascript作用域这块,可以说颠覆了以前我对作用域的认识。类似Java和C等编程语言,在花括号“{}”内的代码都是有各自的作用域的,并且在这个范围以外,这些变量是不可见的,我们称这种作用域为  块级作用域  。

但是这完全不适用于Javascript,因为Javascript没有块级作用域,但是Javascript有  函数作用域  。函数作用域简言之就是:变量在声明他们的函数体以及这个函数体嵌套的任意函数体内都是有定义的。

对于“ 变量在声明他们的函数体以及这个函数体嵌套的任意函数体内都是有定义的 ”这句话的延伸理解:变量在声明之前就已经可用。我们称这种特性为声明提前,也就是函数里的所有变量都被“提前”至函数体的顶部。

下面我们看一个经典的陷阱案例:

var v = "yoyo"; (function(){ console.log(v); var v = "check now";     console.log(v); })();

怎么理解JS另类的作用域

对于第二次执行结果“check now”没有什么特别的,为什么***次输出的不是“yoyo”而是“undefined”。

对于这个问题的解释就用到上面的那句话,  局部变量在整个函数体始终是有定义的  ,即在函数体内局部变量覆盖了同名全局变量,而且,程序只有在执行到var语句时,局部变量才会被真正赋值。所以,这时你大概会明白为什么是undefined了,因为此时还没有遇到var,即没有定义,等价于下面的形式:

var v = "yoyo"; (function(){ var scope; console.log(v); var v = "check now";     console.log(v); })();  疑问 ? ? ?  将上面的代码稍稍修改为:  var v = "yoyo"; (function(){     console.log(v); })();

运行结果为:

怎么理解JS另类的作用域

相比于上面的代码只是少了一行添加一个局部变量v并赋值的语句,但是结果却是“yoyo”。

这里之所以输出“yoyo”,不能按照上面的定式思维。上面有句话叫“局部变量在整个函数体始终是有定义的”,但是这里没有局部变量的定义,所以按照下面要提到的作用域链会逐层向上寻找变量,***找到了全局变量v,从而***的输出是“yoyo”。

以上是我的个人理解,如果你对这两种情况有自己的理解,请在下方给出,望不吝指教。

3.作用域链

全局变量在程序中始终是有定义的,局部变量在声明它的函数体内以及其所嵌套的函数内始终是有定义的。

每一段Javascript代码(全局代码或函数)都有一个与之相关联的作用域链,这个作用域链就是一个对象列表或链表。比如当 Javascript需要查找变量x的值时,它会从链中的***个对象开始,如果该对象有一个名为x的属性,则直接使用,如果不存在名为x的属性,则会继续 向链上的下一个对象查找,如此递归下去直到找到。如果整个链上都找不到,则认为不存在x这个属性。举例:

name="lwy"; function t(){ var name="tlwy"; function s(){ var name="slwy"; console.log(name); } function ss(){ console.log(name); } s();   ss();  }  t();

怎么理解JS另类的作用域

到此,相信大家对“怎么理解JS另类的作用域”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: 怎么理解JS另类的作用域

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

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

猜你喜欢
  • 怎么理解JS另类的作用域
    本篇内容主要讲解“怎么理解JS另类的作用域”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解JS另类的作用域”吧!1.变量的作用域稍微有些编程背景的都知道,...
    99+
    2024-04-02
  • JS作用域链怎么用
    这篇文章主要为大家展示了“JS作用域链怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JS作用域链怎么用”这篇文章吧。具体内容如下1、所有全局变量和函数都是...
    99+
    2024-04-02
  • js作用域链怎么使用
    这篇文章主要介绍js作用域链怎么使用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!说明只要是代码,至少有一个作用域。写在函数内部的局部作用域。如果函数中有函数,在这个功能域中可以诞生另一个功能域。根据内部函数可以访问...
    99+
    2023-06-20
  • JS作用域作用链及this使用原理详解
    目录变量提升的原理:JavaScript的执行顺序第一部分:变量提升部分的代码第二部分:代码执行部分代码执行阶段调用栈:栈溢出的原理如何利用调用栈1.使用浏览器查看调用栈的信息2.小...
    99+
    2022-11-13
    JS作用域作用链this JS作用域作用链
  • js作用域及作用域链工作引擎怎么应用
    本文小编为大家详细介绍“js作用域及作用域链工作引擎怎么应用”,内容详细,步骤清晰,细节处理妥当,希望这篇“js作用域及作用域链工作引擎怎么应用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、作用域(scope...
    99+
    2023-07-02
  • js中的this作用域全解析
    目录this作用域问题函数式调用方法调用模式在数组中的特例构造器调用模式call、apply、bind特殊情况——箭头函数综合例题this作用域问题 一般来说...
    99+
    2022-11-13
    js中this this作用域 js this作用域
  • JS作用域和作用域链的区别是什么
    本篇内容介绍了“JS作用域和作用域链的区别是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!作用域(Sc...
    99+
    2024-04-02
  • 怎么理解ES6块级作用域
    这篇文章主要介绍“怎么理解ES6块级作用域”,在日常操作中,相信很多人在怎么理解ES6块级作用域问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么理解ES6块级作用域”的疑惑...
    99+
    2024-04-02
  • js中作用域和作用域链及预解析的示例分析
    小编给大家分享一下js中作用域和作用域链及预解析的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!变量---->局部...
    99+
    2024-04-02
  • 理解 C++ 函数返回值类型的作用域
    c++++ 函数返回值类型的作用域仅限于函数体内,用于指定函数返回的值的数据类型,有助于确保类型安全和正确使用返回的值。 理解 C++ 函数返回值类型的作用域 在 C++ 中,函数的返...
    99+
    2024-04-13
    函数 c++ 返回值 作用域
  • JS变量作用域是什么
    这篇文章主要讲解了“JS变量作用域是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JS变量作用域是什么”吧!变量的作用域,指的是变量在脚本代码中的可读、...
    99+
    2024-04-02
  • 理解javascript中作用域
    本篇内容主要讲解“理解javascript中作用域”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“理解javascript中作用域”吧! ...
    99+
    2024-04-02
  • js词法作用域与this实例详解
    目录前言实践总结前言 静态作用域又叫做词法作用域,采用词法作用域的变量叫词法变量。词法变量有一个在编译时静态确定的作用域。词法变量的作用域可以是一个函数或一段代码,该变量在这段代码区...
    99+
    2024-04-02
  • c#怎么调用另一个类的方法
    在 c# 中调用另一个类的方法有三种方式:直接调用:创建该类的实例,然后使用实例调用方法。通过接口调用:创建接口,定义要调用的方法;创建实现该接口的类;使用接口创建类的实例,然后通过接口...
    99+
    2024-05-14
    c#
  • 域名转发到另一个域名的操作方法是什么
    域名转发可以通过以下几种方法实现:1. 通过网站托管服务提供商的控制面板进行设置,一般会有域名转发或者重定向的选项,可以将原域名的访...
    99+
    2023-06-10
    域名转发 域名
  • 怎样理解JavaScript中的变量与作用域
    怎样理解JavaScript中的变量与作用域,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1、原始值与引用值6种简单数据类型的值都是原始值, 原始值通过变量赋值给另一个变量时,...
    99+
    2023-06-25
  • 怎么理解js中的typeof用法
    本篇内容介绍了“怎么理解js中的typeof用法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!基础typeof 运算符是 javascrip...
    99+
    2023-06-25
  • 怎么使用作用域与作用域链
    这篇文章主要讲解了“怎么使用作用域与作用域链”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用作用域与作用域链”吧!一、作用域如果说执行上下文是代码的执...
    99+
    2024-04-02
  • js变量中作用域的使用示例
    这篇文章主要介绍js变量中作用域的使用示例,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!JavaScript是什么JS是JavaScript的简称,它是一种直译式的脚本语言,其解释器被称为JavaScript引擎,是...
    99+
    2023-06-14
  • 理解Golang函数变量的作用域
    理解Golang函数变量的作用域,需要具体代码示例在Golang中,函数是一种特殊的变量类型,可以作为参数传递给其他函数,也可以作为返回值返回。而函数变量的作用域则是指函数变量在代码中可见和可访问的范围。函数变量的作用域可以分为全局作用域和...
    99+
    2023-12-23
    变量作用域 Golang函数 理解 Golang
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作