js学习笔记44——作用域

作用域指一个变量作用的范围。
如下代码,

    <script>
        function fun(){
            var a=1;
        }
        console.log(a);
    </script>

在这里插入图片描述
报错,因为,a是在函数里,作用域不在函数外。

js有两种作用域:全局作用域和函数作用域

全局作用域

直接编写在script标签中的代码。
在页面打开时创建,关闭时销毁。在全局作用域中有一个全局对象window,可以直接使用。

    <script>
        console.log(window);
    </script>

在这里插入图片描述
在全局作用域中,创建的变量都会作为window对象的属性保存。

    <script>
        var a=10;
        console.log(window.a);
        console.log(window.b);
    </script>

在这里插入图片描述

    <script>
        function fun() {
            console.log("我是fun函数");
        }
        window.fun();
    </script>

在这里插入图片描述

变量的声明提前

变量

看代码

    <script>
        console.log(a);
        var a=123;
    </script>

在这里插入图片描述
这里变量声明放在了下面
如果把var去掉会怎样?

    <script>
        console.log(a);
        a=123;
    </script>

在这里插入图片描述
报错了。
为啥有个var就不会报错呢?
原因:使用var声明的变量,会在所有代码执行之前被声明。(不过赋值则是按代码顺序的,所以结果是undefined)

函数

看代码

			
			fun();
			function fun(){
				console.log("我是一个fun函数");
			}
			
			var fun2 = function(){
				console.log("我是fun2函数");
			};

在这里插入图片描述

			fun2();
			function fun(){
				console.log("我是一个fun函数");
			}
			
			var fun2 = function(){
				console.log("我是fun2函数");
			};

在这里插入图片描述
这里报错了,看看fun2存不存在

			console.log(fun2);
			function fun(){
				console.log("我是一个fun函数");
			}
			
			var fun2 = function(){
				console.log("我是fun2函数");
			};

在这里插入图片描述
存在,只是是undefined,undefined不是函数,所以报错。

第一种函数创建方法是使用函数声明的方法,它会在所有代码执行之前就被创建,所以调用没有问题。而第二种是创建方法是函数表达式,它只是声明提前,但没有创建函数。

函数作用域

调用函数时创建函数作用域,函数执行完毕后函数作用域销毁。
在函数里可以访问全局变量。

    <script>
            var a = 10;
			function fun(){
				console.log(a);
			}
            fun();
    </script>

在这里插入图片描述
函数外不能访问函数里的变量。

    <script>
            var a = 10;
			function fun(){
                var b = 10;
				console.log(a);
			}
            fun();
            console.log(b);
    </script>

在这里插入图片描述
在函数中访问变量时,会先在函数作用域里找,如果没有才去外部找。

    <script>
            var a = 10;
			function fun(){
                var a=50;
				console.log(a);
			}
            fun();
            console.log(a);
    </script>

在这里插入图片描述
这种向外找是一级一级的,比如嵌套了好几个函数,则是往外一层一层找,找到为止,否则报错。

如果想在函数里用全局的变量,要怎么做?
使用window对象。

    <script>
            var a = 10;
			function fun(){
                var a=50;
				console.log(window.a);
			}
            fun();
            console.log(a);
    </script>

在这里插入图片描述
如果在函数里修改全局变量的值,会怎样?

    <script>
            var a = 10;
			function fun(){
                a=50;
			}
            fun();
            console.log(a);
    </script>

在这里插入图片描述
所以,函数里可以修改全局的值。

还有一点,函数里没有加var的变量,都是全局变量,而不是函数变量。

    <script>
			function fun(){
                c=50;
			}
            fun();
            console.log(c);
    </script>

在这里插入图片描述
最后,函数中的形参相当于声明了函数变量,所以不会往函数外找。

    <script>
            var a=10;
			function fun(a){
                console.log(a);
			}
            fun();
    </script>

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小欣CZX

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值