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会创建一个新的作用域,来作为当前作用域的子域,然后切换至这个新建的子作用域,开始执行函数逻辑。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值