《悟透JavaScript》中的知识点

简单的数据类型只有undefined, null, boolean, number和string。

typeof(undefined)返回的也是undefined。

typeof(null)返回object,但null并非object,具有null值的变量也并非object。

typeof(NaN)和typeof(Infinity)都返回Number。NaN参与任何数值计算的结果都是NaN,而且NaN!=NaN,Infinity/Infinity=NaN。

JavaScript里“===”表示“全等”,也就是数据值与数据类型都必须相等才是true。如undefined==null、”123”==123是true,但undefined===null、”123”===123是false。

 

JavaScript函数只是一个命了名的变量,变量类型即为function,变量的值就是我们编写的函数代码体。所以下面两段代码除了一点细微的差别,其内部实现完全相同。

定义式

   1: <script type="text/javascript">
   2:     function myfunc(){
   3:         alert("hello");
   4:     }
   5:     alert(typeof myfunc);
   6: </script>
变量式
   1: <script type="text/javascript">
   2:     var myfunc = function(){
   3:         alert("hello");
   4:     }
   5:     alert(typeof myfunc);
   6: </script>

细微的差别在于,Javascript执行引擎并非一行一行地分析和执行程序,而是一段一段地分析执行的。而且,在同一段程序的分析执行中,定义式的函数语句会被提取出来优先执行。函数定义执行完之后,才会按顺序执行其他语句代码。也就是说,两个相同函数名的定义式的函数在同一段程序中时,第一个函数将被第二个函数覆盖,所以代码段中所有调用此函数的地方执行的都是第二个函数定义中的语句。

   1: <script type="text/javascript">
   2:     var myfunc = function(){
   3:         alert("hello");
   4:     }
   5:     myfunc();
   6:     myfunc = function(){
   7:         alert('yeah');
   8:     }
   9:     myfunc();
  10: </script>

结果:第一个弹出“hello”,第二个弹出“yeah”。

   1: <script type="text/javascript">
   2:     function myfunc(){
   3:         alert("hello");
   4:     }
   5:     myfunc();
   6:     function myfunc(){
   7:         alert('yeah');
   8:     }
   9:     myfunc();
  10: </script>

结果:两个都弹出“yeah”。

   1: <script type="text/javascript">
   2:     function myfunc(){
   3:         alert("hello");
   4:     }
   5:     myfunc();
   6: </script>
   7: <script type="text/javascript">
   8:     function myfunc(){
   9:         alert('yeah');
  10:     }
  11:     myfunc();
  12: </script>
结果:第一个弹出“hello”,第二个弹出“yeah”。

 

在JavaScript里的全局环境就是一个对象,这个对象是JavaScript运行环境的根。对于浏览器中的JavaScript来说,这个根对象就是window对象。对于全局的JavaScript来说,window对象就相当于当前作用域。

“var”定义的是作用域上的一个变量,而没有“var”的标识符却可能是全局根对象的一个属性。

当代码运行进入一个函数时,JavaScript会创建一个新的作用域,来作为当前作用域的子域,然后切换至这个新建的子作用域,开始执行函数逻辑。

posted @ 2010-10-26 14:53  文野  阅读(960)  评论(0编辑  收藏  举报