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();
这时候结果是什么呢?
经过验证结果是:undefined
如果代码是这样呢:
var i = 'yuanjianhang';
function myloveName() {
alert(i);
}
myloveName();
此时i的结果是:yuanjianhang
为什么会发生上面undefined情况,因为代码的执行顺序是从上到下的,在输出i之前并没有对i定义。所以从这里可以看出,使用代码的时候,变量的声明一定要放到代码的前面,以避免出现类似的问题!
同理:
var i = 'yuanjianhang';
function myloveName() {
alert(i);
var i = 'guanxi';
}
myloveName();
这种情况下也会输出:undefined
好了,关于变量我只有这么多的介绍了,相信这些任何人都可以看明白。不管代码如何复制,其核心是不会变的,祝大家学习愉快!
分享到:
相关推荐
JavaScript 变量作用域详解 JavaScript 变量作用域是基于其特有的作用域链的。在 JavaScript 中,变量作用域是指变量可以被访问和修改的范围。 JavaScript 没有块级作用域,而是基于函数作用域和全局作用域的。 ...
相关于JavaScript变量的应用以及相关解释。
理解JavaScript变量作用域.pdf 本人还有几十本经典javascript书籍以及无数javascript资料,要的加我qq 568094881,本人网址:www.maoshanhai.com
JavaScript变量遵循特定的命名规则: 1. 变量名必须以字母、下划线(_)或美元符号($)开头。 2. 变量名可以包含字母、数字、下划线或美元符号,但不能包含空格或其他特殊字符。 3. 变量名是区分大小写的,`y`和`Y`...
JavaScript中的变量声明是编程的基础,理解这一概念对于编写健壮的代码至关重要。本文将深入探讨JavaScript中的变量声明,包括全局变量、...对于更多JavaScript变量声明的深入学习,可以参考IT技术专栏获取相关信息。
第2节 JavaScript变量.rar第2节 JavaScript变量.rar第2节 JavaScript变量.rar第2节 JavaScript变量.rar第2节 JavaScript变量.rar第2节 JavaScript变量.rar第2节 JavaScript变量.rar第2节 JavaScript变量.rar第2节 ...
JavaScript变量作用域是编程语言中一个非常核心的概念,它决定了变量在何处可被访问以及其生命周期。在这道面试题中,我们看到的是如何在不同作用域下声明和使用变量,特别是与for循环相结合的情况。 首先,我们要...
简单的javascript变量示例
在进行Web开发时,尤其是使用JSP技术开发动态网站时,我们常常需要处理服务器端Java变量与客户端JavaScript变量之间的数据交互问题。JSP(JavaServer Pages)是一种用于开发动态网页的技术,它允许我们在HTML页面中...
JavaScript,又被称为JS...总之,JavaScript的变量和函数是其核心组成部分,理解它们对于掌握JavaScript编程至关重要。深入学习这些概念,不仅可以帮助编写出更有效的代码,也有助于理解和解决在实际开发中遇到的问题。
JavaScript变量,数据类型,运算符【JavaScript全栈入门教程2】
主要给大家介绍了关于Javascript变量的相关问题,文中给出了详细的介绍和示例代码,相信对大家的理解和学习具有一定的参考借鉴价值,有需要的朋友们下面来一起看看吧。
javascript变量 思维导图; 可以用MindManager 、XMind 、百度脑图打开;在这个的基础上面添加自己的理解,整理成自己的个人知识体系
本文实例讲述了JavaScript变量基本使用方法。分享给大家供大家参考,具体如下: JavaScript 是一种弱类型语言,javascript的变量类型由它的值来决定。 定义变量需要用关键字 ‘var’ var iNum = 123; var sTr = '...
javascript变量大全 所有精华 集于一图 一目了然 形象易懂 十分中肯
1.区分大小写 [removed] ... 全部的变量都用var关键字标示,JavaScript解释器会自动分配 3.句子的尾部分号是可选的 如:var name=23; or var name=23都可以 <script language=’javascript’
2. **JavaScript资产(JavaScript Assets)**:如果你的变量非常复杂或者包含大量数据,可能需要创建一个JavaScript文件来接收这些数据。在Laravel的`resources/js`目录下创建一个新的JS文件,然后通过`mix`编译。在...
JavaScript变量声明是编程基础中的重要一环,理解变量声明对于编写有效的JS代码至关重要。本文将深入探讨JavaScript中的变量声明方式,以及与之相关的全局变量、局部变量、隐式全局变量和“hoisting”(悬置/置顶...
在JavaScript中,变量是编程的基础元素,用于存储和处理数据。本篇将深入探讨JavaScript中的变量及其相关概念。 ### 2.2.1 什么是变量 1. **字面量**:在编程中,字面量是指直接表示特定值的符号,如数字(123)、...