新闻资讯当前位置:帝豪2娱乐 > 新闻资讯 > >

JavaScript预解析及相关技巧分析

  

[JavaScript,预解析]JavaScript预解析及相关技巧分析

  

本文实例讲述了JavaScript预解析及相关技巧。分享给大家供大家参考,具体如下:  

  

变量  

  

同样,以这两个小例子的错误对比提示开始。

  

  
  
  alert(y1);     //代码段1  var y1 = 'dddd';  alert(y2);     //代码段2 // alert(typeof y2);  y2 = 'xxxxx';  
  
  

先思考一下,为什么一个会提示 undefined , 一个却抛出变量未定义的错。。先看JavaScript的解析过程。

  

  

javascript在执行过程之前,会做一件事件“预解析”。解析引擎会以块为单位级别,执行所有 var 变量的创建,并赐予它们一个初始值:undefined。这样一来,第一个例子为什么会弹出undefined的原因就显而易见了。

  

  

所以第一段代码其实就等价于  

  
  
  var y1;  alert(typeof y1); //很自然,它此时值为undefined  y1 = 'dddd';  
  
  

那第二段代码为什么又抛错呢,此时就不再属于“预解析”阶段了,(在这里我假设浏览器遇到一个script标签时只做两件事:预解析和执行,其实不 只这两件事情),而处于执行阶段,抛错原因在于js在执行段状态并不知晓y2的状态(预解析阶段没有捕获到y2的任何信息),当然就抛出未定义的错误信 息。这里又牵扯到另一个问题: js 是弱类型语言,变量不定义可以用,那为什么这里又抛出为定义错误呢。

  

  

事出总有因,javascript总有很多自身奇怪的特性,有一个叫变量的读写不均等。未定义的变量,仅仅是可写,并不可读。何为可写,每个人都熟悉这样的写法:  

  
  
  y2 = 'exam';  //在没出现它的定义操作之前(即在它还没有自己的scope之前)该操作会将这段代码认为是定义一个全局变量,在window上注册一个属性y2,并赋值为exam  
  
  

但在对它的读操作,js引擎搜寻不到它的任何相关信息,就以自己的脾气行事,毫不客气抛一个未定义的错,这是js的游戏规则。还有但是,那为什么却 可以获取它的类型呢。还记得 js对对象的操作吧。如果访问对象一个不存在的属性及类型,会提示undefined, (因为它当前是window对象的一个属性)。

  

  

再注:这里需要区分, 变量的读写不均等 仅用于变量,读取所有对象的属性,不存在该特性,如果不存在,会提示undefined。

  

  

结论  

  

到这里,我的思考结果: 对于变量和对象的写操作,他们有一定的类似之处.但是读操作,各有各的一套规则,正因为此,所以有了上面的问题。

  
  这样一来,下面这个题应该就很容易得到答案了吧。

  

  
  
  if (!('a' in window)) {  var a = 1;  }  alert(a);  
  
  

函数  

  

引申一下,function. 还记得上面提到的预解析,在javascript的预解析中,除了对var 变量的预定义,还包括了提取对函数的定义,所以可以在script的任何地方定义函数,在任何地方调用。不限于它之前.

  

  

但函数的定义方式,包括了一种叫字面量定义法, 用var的方法声明function.看下面  

  
  
  alert(typeof y3); //结果?

  var y3 = function (){ console.log('1'); }  

  
  

还记得这个约定吧:调用必帝豪娱乐平台须出现在声明之后,为什么呢,如果理解了上面,其实这里答案已经明了。javascript 引擎在预解析 var 时 会给他们一个初始值 undefined,这样一来,如果我们在它的声明之前调用它,javascript 引擎还没拿到它的真实值,自然会报"xxx is not a function" 的错.这也理清了为什么同为函数声明,一个却关系到声明和调用的顺序,一个却无这样的约束。

  

  

结论  

  

它是函数,是js执行,动态修改的结果,依然遵循了变量的预解析规则(在上面alert的时候,它还并没有拿到字面量函数的信息)。

  
  如果是两个混合呢。看下面, 同时存在了为y4的变量和function。

  

  
  
  alert(typeof y4); //结果?

  function y4(){  console.log('y4')  }  var y4;  

  
  

因为 javascript 在预解析时function的声明优先级高的缘故,所以y4自然为function类型, 但是在当y4 赋值之后(此时js引擎处于执行过程中),它对js的赋值操作将会覆盖function的声明。所以:   (责任编辑:admin)

上一篇:帝豪娱乐平台:bootstrap css样式之表单

下一篇:没有了

推荐内容