javascript变量作用域使用中常见错误总结

 更新时间:2013年03月26日 11:14:11   作者:  
刚看了一篇文章对js作用域的理解又会上升到一个新的台阶,javascript里变量作用域是个经常让人头痛抓狂的问题,接下来对经常遇到又容易出错的情况进行了简单总结,感兴趣的各位可以参考下哈

今天在rainweb的博客上,看到了这篇非常好的文章,觉得非常有必要分享出来,相信大家认真读完这篇文章,对js作用域的理解又会上升到一个新的台阶。

前言:javascript里变量作用域是个经常让人头痛抓狂的问题,下面通过10++个题目,对经常遇到又容易出错的情况进行了简单总结,代码样例很短很简单

题目一

复制代码 代码如下:

var name = 'casper'; alert(name); //毫无疑问地输出:casper

题目二
复制代码 代码如下:

alert(name); //报错:对象未定义,即使用一个压根就不存在的变量,所以出错
age = 24; //这里木有错,但age不是为定义吗?翻下犀牛书,明白了 //给一个未定义的变量赋值,会创建一个全局变量,相当于:var age = 24

题目三
复制代码 代码如下:

alert(name); //name下面才定义,这里肯定报错了吧?错!这里弹出:undefined
var name = 'casper';

解释:javascript代码在解析的时候,都会搜索下var声明的变量,并将其声明提前,实际的过程如下:
复制代码 代码如下:

var name; //光声明name变量,但未赋值,所以为此时为:undefined
alert(name); name = 'casper';

题目四
复制代码 代码如下:

var name = 'casper';
function show(){
alert(name);
name = 'hello'; //全局变量name的值改为'hello'
}
show(); //输出:casper

题目五
复制代码 代码如下:

var name = 'casper';
function show(){ alert(name); //输出:undefined,是不是有想死的心
var name = 'hello'; //注意:与题目四相比,此处name前多了个var,
} show();

解释:在函数show中,name是个局部变量,题目三的原理同样适用于此,即函数show内部实际为
(小知识点补充:当函数内部存在与外部全局变量同名的局部变量,优先使用局部变量,此处为name)
function show(){ var name; alert(name); name = 'hello'; }
题目六
复制代码 代码如下:

var list = [1,2,3];
function show(){ if(typeof list === 'undefined')
{ list = []; }
alert(list.length);
};
show(); //结果:3,是不是一目了然= =,稍等,请接着看第七题

题目七
复制代码 代码如下:

var list = [1,2,3];
function show(){
if(typeof list === 'undefined')
{ var list = []; //请注意,与题目六相比,这里多了个var
} alert(list.length); };
show(); //结果:0,是不是突然有了想死的冲动

解释:javascript没有块级作用域(即由{}限定的作用域),函数中声明的所有变量,无论在哪里声明,在整个函数中都是有定义的,这点跟C++等灰常不同,赶紧扭转思想与时俱进
于是,再来看下show方法实际的内部解析逻辑
复制代码 代码如下:

function show(){ var list; //list为局部变量,且此处尚未赋值
if(typeof list === 'undefined'){
list = []; }
alert(list.length); };

题目八
复制代码 代码如下:

alert(typeof show); //结果:function,请相信你的眼睛,你没有看错
function show(){}

解释:javascript代码解析的过程,类似 function show() 这种形式声明的函数,跟var声明的变量一样,都会被提到最前面,不同的是,函数声明跟定义同时完成,但var声明的变量的赋值在后面才会完成
题目九
复制代码 代码如下:

alert(typeof show); //结果:undefined,请再次擦亮你的眼睛,你的确没有看错
var show = function(){};

解释:采用函数定义式以及函数表达式定义函数,两者过程之间存在一些区别
函数定义式:function show(){}
函数表达式:var show = function(){}
采用函数定义式声明的方法,函数的定义会提前;而采用函数表达式声明的方法,函数的定义,跟采用var声明的局部变量一样,函数声明会提前,但函数定义位置不变,过程如下:
复制代码 代码如下:

var show; alert(typeof show);
show = function(){};

题目十
复制代码 代码如下:

var data = {name:'casper'};
function data(){ alert('casper'); }
data(); //TypeError: object is not a function

是不是有砸显示器的冲动。。。data此时其实为{name:'casper'},把一个object当函数调用,于是报错了
前面说过,函数声明(通过函数定义式)、var声明的变量会被提前,但是会有先后顺序之分,如下:
复制代码 代码如下:

function data(){ alert('casper');
} var data; data = {name:'casper'};
data();

略微修改下,结果就不同鸟:
复制代码 代码如下:

var data = {name:'casper'};
var data = function (){ //通过函数表达式声明函数
alert('casper'); }
data(); //结果:casper

结合上文不难猜想过程如下:
复制代码 代码如下:

var data; data = {name:'casper'};
data = function (){ alert('casper'); }
data(); //结果:casper

相关文章

  • js自定义回调函数

    js自定义回调函数

    这篇文章主要介绍了javascript自定义回调函数,感兴趣的小伙伴们可以参考一下
    2015-12-12
  • 脚本分析、压缩、混淆工具 JSA新版本发布,压缩效率提高大约10%

    脚本分析、压缩、混淆工具 JSA新版本发布,压缩效率提高大约10%

    脚本分析、压缩、混淆工具 JSA新版本发布,压缩效率提高大约10%...
    2007-05-05
  • JavaScript中filter的用法实例分析

    JavaScript中filter的用法实例分析

    这篇文章主要介绍了JavaScript中filter的用法,结合实例形式分析了filter的功能、使用方法及相关操作注意事项,需要的朋友可以参考下
    2019-02-02
  • javascript遍历对象的五种方式实例代码

    javascript遍历对象的五种方式实例代码

    在我们日常工作过程中,我们对于javaScript遍历对象、数组的操作是十分的频繁的,这篇文章主要给大家介绍了关于javascript遍历对象的五种方式,需要的朋友可以参考下
    2021-10-10
  • 一文学会用JS判断文字是否被省略(ellipsis)

    一文学会用JS判断文字是否被省略(ellipsis)

    这篇文章主要给大家介绍了用JS如何判断文字被省略ellipsis,CSS帮我们搞定了省略,但是JS并不知道文本什么时候被省略了,所以我们得通过JS来计算,接下来,我将介绍2种方法来实现JS计算省略,需要的朋友可以参考下
    2023-08-08
  • electron中获取mac地址的实现示例

    electron中获取mac地址的实现示例

    在基于Electron的应用中,有一个业务需求是获取物理网卡的Mac地址以用于客户机唯一性识别,本文主要介绍了electron中获取mac地址的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2023-12-12
  • javascript实现获取图片大小及图片等比缩放的方法

    javascript实现获取图片大小及图片等比缩放的方法

    这篇文章主要介绍了javascript实现获取图片大小及图片等比缩放的方法,涉及javascript针对图形图像相关属性获取与修改相关操作技巧,需要的朋友可以参考下
    2016-11-11
  • TypeScript中let和var的区别介绍

    TypeScript中let和var的区别介绍

    这篇文章主要介绍了TypeScript let与var的区别,主要从作用域等这几个方面做详细介绍,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • JavaScript基于自定义函数判断变量类型的实现方法

    JavaScript基于自定义函数判断变量类型的实现方法

    这篇文章主要介绍了JavaScript基于自定义函数判断变量类型的实现方法,结合实例形式分析了javascript判断变量类型的自定义函数定义与使用方法,并针对不同浏览器给出了相关的分析与说明,需要的朋友可以参考下
    2016-11-11
  • JS封装的自动创建表格的实现代码

    JS封装的自动创建表格的实现代码

    这篇文章主要介绍了JS封装的自动创建表格的实现代码的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-06-06

最新评论