博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【JavaScript】全局变量与局部变量
阅读量:4286 次
发布时间:2019-05-27

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

javascript有两种变量:局部变量和全局变量。当然,我们这篇文章是帮助大家真正的区别这两种变量。

首先,局部变量是指只能在本变量声明的函数内部调用。全局变量是整个代码中都可以调用的变量。当然,单单从字面上理解肯定是不清楚的,下面我详细的介绍下:

大家都知道,变量是需要用var关键字声明的。但是javascript中也可以隐式的使用变量,就是不用声明,直接使用。而且,千万注意,javascript把隐式声明的变量总是当成全局变量来使用的。
例如:

代码如下:

function myName() {
i = 'yuanjianhang';}myName();function sayName() {
alert(i); } sayName();

输出结果为:yuanjianhang

这说明变量i就是一个全局的变量,如果把上面的代码改成如下:

function myName() {
var i='yuanjianhang';}myName();function sayName() {
alert(i);}sayName();

此时,游览器将没有任何输出结果,因为i 是在函数myName中定义的,所以它只是myName的局部变量,不可能被外部调用。

现在再回过头来看下面的代码:

function myName() {
i = 'yuanjianhang';}myName();function sayName() {
alert(i);}sayName();

现在,我们进行一下改动,把myName();去掉,代码如下:

代码如下:

function myName() {
i = 'yuanjianhang';}function sayName() {
alert(i);}sayName();

此时,游览器也不会有如何反应。因为虽然i是全局变量,但是函数myName()并没有被调用,所以就相当于虽然声明了i,但是并没有给i赋予任何的值,所以没有任何输出。

同理,如果把上例改成:

代码如下:

function myName() {
i = 'yuanjianhang';}function sayName() {
alert(i);}sayName();myName();

这种情况下还是不会输出任何结果,javascript代码的执行是从上到下的,在sayName()函数被调用时会检查变量i的值,此时函数myName尚未执行,也就是说i还没有被赋值,所以不会输出任何结果。

为了方便大家更好的理解,这里再举一个例子:

代码如下:

var i = 'yuanjianhang';function myloveName() {
i = 'guanxi';}myloveName();function myName() {
alert(i);}myName();

这次的结果是什么呢?

答案是guanxi

首先,i的原始值是yuanjianhang,但是当调用myloveName()函数之后,将i的值改为guanxi,所以最后的输出结果是guanxi。

如果将代码改为:

代码如下:

var i = 'yuanjianhang';function myloveName() {
var i = 'guanxi';}myloveName();function myName() {
alert(i);}myName();

此时的结果就是yuanjianhang了,因为代码中的两个i不一样,一个是全局的,一个是局部的,也可以这样理解,虽然两个i的名字一样,但是这两个i的本质却不一样,好像有两个名字一样的人一样,虽然名字一样,但却不是同一个人。

如果将代码改造成这样:

代码如下:

var i = 'yuanjianhang';function myloveName() {
i = 'guanxi';}function myName() {
alert(i);}myName();myloveName();

相信大家可以自己算出结果了,结果是yuanjianhang。

既然函数内部可以调用全局变量,那么下面这种情况呢:

代码如下:

var i = 'yuanjianhang';function myloveName() {
i = 'guanxi'; alert(i);}myloveName();

此时变量的值是哪个呢?

我们来分析下:

首先全局变量i被赋值为:yuanjianhang。

接下来myloveName()函数被调用,全局变量i被重新赋予新的值:guanxi

所以结果肯定是:guanxi。

如果我们把alert提前呢,像这样:

代码如下:

var i = 'yuanjianhang';function myloveName() {
alert(i); i = 'guanxi';}myloveName();

这时候结果是什么呢?

注意输出的结果为"yuanjianhang",从idea截图看出此时i都是使用的函数外的全局变量
在这里插入图片描述

如果代码是这样呢:

复制代码代码如下:

var i = 'yuanjianhang';function myloveName() {
alert(i);}myloveName();

此时i的结果是:yuanjianhang

再看下面的代码

代码如下:

var i = 'yuanjianhang';function myloveName() {
alert(i); var i = 'guanxi'; }myloveName();

这种情况下会输出:undefined

从idea截图看出,因为认定函数内的两个i都为局部变量,而函数内局部变量都没有定义,就调用了当然是undefined。从这里得出只要函数内的变量有var修饰的,以及没有用var修饰的同名变量,均视为局部变量

在这里插入图片描述
小结:
函数内部定义的局部变量与全局变量重名时,函数在使用该变量的时候会以局部变量覆盖全局变量,也就是只有局部变量会起效果。
参考链接
https://blog.csdn.net/weixin_40133326/article/details/84782702
https://blog.csdn.net/xh_xinhua/article/details/89417032

你可能感兴趣的文章
javascript(四)之window
查看>>
javascript(五)之框架
查看>>
WKWebView 和UIWebView、网页缓存、网路请求缓存
查看>>
Javascript (六)高级之ECMAScript
查看>>
iOS之UISCrollView--原理
查看>>
iOS 之NSRange实现小数向上取整
查看>>
PHP 之XML编程,注释总结
查看>>
iOS之SHA1算法
查看>>
iOS之hHTTPS的使用
查看>>
iOS之返回按钮
查看>>
PHP 之smarty、webservice、RSS订阅
查看>>
iOS之静态库
查看>>
iOS 之适配字体的几中方法
查看>>
iOS之view的背景绘制渐变色、文字渐变
查看>>
javascript之(四)作用域链,闭包
查看>>
javascript之(五)面下个对象
查看>>
javascript之(六)正则表达式
查看>>
javascript之贪吃蛇案例
查看>>
javascript 之AJAX(一)
查看>>
javascript之AJAX(二)json
查看>>