Javascript作用域(局部和全局作用域)详细介绍

 更新时间:2023年06月06日 10:18:31   作者:下一站丶  
作用域是当前的执行上下文,值和表达式在其中“可见”或可被访问,本文主要介绍了Javascript局部作用域和全局作用域,文中有详细的代码示例,具有一定的参考价值,需要的朋友可以借鉴一下

Javascript作用域 (局部作用域和全局作用域) 详细介绍

作用域是当前的执行上下文,值和表达式在其中“可见”或可被访问。

常见的作用域为:
全局作用域:脚本模式运行所有代码的默认作用域
函数作用域:由函数创建的作用域
局部作用域:用对象{}包着(一个代码块)创建出来的作用域

在了解作用域之前先看一下全局变量和局部变量

  • 全局变量
    1、在全局作用域下声明的变量叫做 全局变量(在函数外部定义的变量)

    2、全局变量在全局(代码的任何位置)下都可以使用;全局作用域中无法访问到局部作用域中的变量。

以下我们用var创建的就是全局变量:

<script>
var value = 66;
    function method(){
        console.log(value);
    }
method();
console.log(value);
</script>

全局变量会提升但并不会赋值:所以 在创建之前log是undefined 的
亿点小知识:变量提升和上文提到触发时间有关。我们知道,var 和 function 声明的变量可以在声明前访问,这就是因为变量提升的缘故。

<script>
    console.log(value); // undefined 
    var value = 66;
	console.log(value); // 66
</script>
  • 局部变量
    1、在局部作用域下声明的变量叫做局部变量(在函数内部定义的变量)

    2、局部变量只能在函数内部使用,在局部作用域中可以访问到全局变量。

在函数的内部创建变量也是局部变量:

<script>
    function method(){
    	var value = 66;
        console.log(value); // 66
    }
method();
console.log(value); //value is not defined
</script>

全局作用域和局部作用域的区别

  • 全局作用域
    全局作用域中的变量称为全局变量,可以在任何作用域内访问。有两种全局变量:

1.全局声明变量是普通变量,在最顶级由 const、let 和 class 声明的变量。
2.全局对象是存储在全局对象中的属性
亿点小知识:所有创建的变量都会作为 window 对象的属性保存

<script>
var value = 66; // 在整个全局都可以获取到 value
    function method(){
        console.log(value); // 全局方法内部也可以获取到 value 
    }
method();
</script>
  • 局部作用域
    作用域对变量来说,可以简单理解为程序能够访问到变量的范围,超过作用域的就无法访问。
{ 
    // 外面这个 a 作用域,可以访问变量 a
    const a = 0; 
    console.log(a); // 0
    {
        // 里面这个 b 作用域,可以访问 a、b
        const b  = 1;
        console.log(a); // 0
        console.log(b); // 1
    }
}
// 最外面的作用域 不能访问 a,b
console.log(a); // 报错:Uncaught ReferenceError: a is not defined
  • 函数作用域
    在函数内部定义的变量,就是局部作用域。函数作用域内,对外是封闭的,从外层的作用域无法直接访问函数内部的作用域
function method(){
    let value = '内容';
}
console.log(value ) //报错:ReferenceError:value is not defined

以上就是Javascript作用域 (局部和全局作用域) 详细介绍的详细内容,更多关于Javascript 作用域的资料请关注脚本之家其它相关文章!

相关文章

  • JavaScript中的回调函数实例讲解

    JavaScript中的回调函数实例讲解

    今天小编就为大家分享一篇关于JavaScript中的回调函数实例讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • Javascript使用post方法提交数据实例

    Javascript使用post方法提交数据实例

    这篇文章主要介绍了Javascript使用post方法提交数据,实例分析了javascript实现post提交数据的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • js 遍历json返回的map内容示例代码

    js 遍历json返回的map内容示例代码

    js 遍历json的方法有很多,在本文为大家详细介绍下如何返回的map内容,感兴趣的朋友可以参考下
    2013-10-10
  • 详解微信小程序与内嵌网页交互实现支付功能

    详解微信小程序与内嵌网页交互实现支付功能

    这篇文章主要介绍了详解微信小程序与内嵌网页交互实现支付功能,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10
  • JavaScript实现HSL拾色器

    JavaScript实现HSL拾色器

    这篇文章主要为大家详细介绍了JavaScript实现HSL拾色器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • JavaScript中变量的相互引用

    JavaScript中变量的相互引用

    变量相互引用的原因是:由于某些类型的变量是按地址存储的而导致的两个或多的参数的值互相影响.
    2010-05-05
  • 事件模型在各浏览器中存在差异

    事件模型在各浏览器中存在差异

    根据 W3C DOM 2 Events 描述,EventTarget 接口被所有支持 DOM 事件模型的节点(Node)实现。 该接口提供addEventListener 和removeEventListener方法,用来绑定或解绑一个 EventListeners 接口到一个 EventTarget。
    2010-10-10
  • JavaScript生成随机验证码代码实例

    JavaScript生成随机验证码代码实例

    这篇文章主要介绍了JavaScript生成随机验证码代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • javascript 拷贝节点cloneNode()使用介绍

    javascript 拷贝节点cloneNode()使用介绍

    这篇文章主要介绍了javascript 节点操作拷贝节点cloneNode()的使用,需要的朋友可以参考下
    2014-04-04
  • js实现GIF动图分解成多帧图片上传

    js实现GIF动图分解成多帧图片上传

    这篇文章主要为大家详细介绍了js实现GIF动图分解成多帧图片上传,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10

最新评论