简介

javascript是一种解释型语言,它的执行是自上而下的。但是各浏览器对于【自上而下】的理解是有细微差别的,而代码的上下游也就是程序流对于程序正确运行又是至关重要的。所以我们有必要深入理解js的执行顺序。为此,我设计了如下八个实验来获得最确切的结果。

实验

  1. <script type="text/javascript">
  2. //实验一:
  3. function t(a)
  4. {
  5. alert("[t(a)]a:" + a);
  6. }
  7. function t(a, b)
  8. {
  9. alert("[t(a, b)]a:" + a + ", b:" + b);
  10. }
  11. t(1);
  12. //结果:
  13. //[t(a, b)]a:1, b:undefined
  14. //实验二:
  15. function t(a, b)
  16. {
  17. alert("[t(a, b)]a:" + a + ", b:" + b);
  18. }
  19. function t(a)
  20. {
  21. alert("[t(a)]a:" + a);
  22. }
  23. t(1);
  24. //结果:
  25. //[t(a)]a:1
  26. //实验三:
  27. function t(a)
  28. {
  29. alert("[t(a)]a:" + a);
  30. }
  31. function t(a, b)
  32. {
  33. alert("[t(a, b)]a:" + a + ", b:" + b);
  34. }
  35. t(1, 2);
  36. //结果:
  37. //[t(a, b)]a:1, b:2
  38. //实验四:
  39. function t(a, b)
  40. {
  41. alert("[t(a, b)]a:" + a + ", b:" + b);
  42. }
  43. function t(a)
  44. {
  45. alert("[t(a)]a:" + a);
  46. }
  47. t(1, 2);
  48. //结果:
  49. //[t(a)]a:1
  50. //实验五
  51. function t(a)
  52. {
  53. alert("[t(a)]a:" + a);
  54. }
  55. t(1);
  56. function t(a, b)
  57. {
  58. alert("[t(a, b)]a:" + a + ", b:" + b);
  59. }
  60. //结果:
  61. //[t(a, b)]a:1, b:undefined
  62. //实验六
  63. function t(a)
  64. {
  65. alert("[t(a)]a:" + a);
  66. }
  67. t(1, 2);
  68. function t(a, b)
  69. {
  70. alert("[t(a, b)]a:" + a + ", b:" + b);
  71. }
  72. //结果:
  73. //[t(a, b)]a:1, b:2
  74. //实验七
  75. function t(a, b)
  76. {
  77. alert("[t(a, b)]a:" + a + ", b:" + b);
  78. }
  79. t(1);
  80. function t(a)
  81. {
  82. alert("[t(a)]a:" + a);
  83. }
  84. //结果:
  85. //[t(a)]a:1
  86. //实验八
  87. function t(a, b)
  88. {
  89. alert("[t(a, b)]a:" + a + ", b:" + b);
  90. }
  91. t(1, 2);
  92. function t(a)
  93. {
  94. alert("[t(a)]a:" + a);
  95. }
  96. //结果:
  97. //[t(a)]a:1
  98. </script>

后记

定义javascript函数时,函数名是函数对象的标识,参数数量只是这个函数的属性。靠定义参数数量不同的函数实现重载是不行的。
调用函数时,js通过函数名找到对应的函数对象,然后根据函数定义时的参数,和表达式参数列表按顺序匹配,多余的参数舍去,不够的参数按undefined处理,然后执行函数代码。

所以定义函数时,通常把必选参数放在参数列表最前面,可选参数放在必选参数后面。

注意事项

一、上述八个实验的结果是经过360浏览器(版本/内核:6.3.1.142/21.0.1180.89)和火狐浏览器(版本:27.0.1)运行得出的。
二、上述八个实验是相互独立的,请分别单独运行以得到正确的结果。

通过实验窥探javascript的解析执行顺序的更多相关文章

  1. JavaScript程序的执行顺序

    JavaScript程序的执行顺序:同步==>异步==>回调 同步是阻塞模式,异步是非阻塞模式.     同步就是指一个进程在执行某个请求的时候,若该请求需要一段时间才能返回信息,那么这个 ...

  2. Javascript加载执行顺序

    本文主要内容 一.不同位置的script标签执行顺序 二.document.ready和window.onload的区别 一.不同位置的script标签执行顺序 整个加载的过程从解析头部开始,比如ht ...

  3. JavaScript Alert 函数执行顺序问题

    * { color: #3e3e3e } body { font-family: "Helvetica Neue", Helvetica, "Hiragino Sans ...

  4. html 和 javascript 的相关执行顺序

    1.dom 树和 js 的加载顺序 http://blog.csdn.net/jdsxzhao/article/details/44646463 2. jquery中各个事件执行顺序如下: https ...

  5. JavaScript代码内部执行顺序

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. JavaScript执行顺序分析

    之前从JavaScript引擎的解析机制来探索JavaScript的工作原理,下面我们以更形象的示例来说明JavaScript代码在页面中的执行顺序.如果说,JavaScript引擎的工作机制比较深奥 ...

  7. javascript的执行顺序(转载)

    之前从JavaScript引擎的解析机制来探索JavaScript的工作原理,下面我们以更形象的示例来说明JavaScript代码在页面中的执行顺序.如果说,JavaScript引擎的工作机制比较深奥 ...

  8. 浏览器环境下JavaScript脚本加载与执行探析之代码执行顺序

    本文主要基于向HTML页面引入JavaScript的几种方式,分析HTML中JavaScript脚本的执行顺序问题 1. 关于JavaScript脚本执行的阻塞性 JavaScript在浏览器中被解析 ...

  9. <script>标签的加载解析执行

    转自原文 <script>标签的加载解析执行 看了很多网上的文章,都是大同小异.总结一下.内部原理还没有搞清楚,有机会再学习. 一.<script>标签的加载解析执行顺序 ht ...

随机推荐

  1. Android_getSystemService (demo_testNet)

    今天主要通过一个案例来看下我们的Android 获取系统服务的问题. 我们通常能够看见登录QQ后如果没有网络的状态的时候,它会告诉你一句话:您进入了没有网络的异次元或者是什么网络连接错误等等.Andr ...

  2. [转] 你是as3老鸟吗?但是有些你可能目前都不知道的东西

    你是as3老鸟吗?如果以下内容对你有莫大的帮助,请顶下! 一:加载swf库中的图片 new 的过程就是图片解压缩的过程.处于 Class 状态时,图片占用的内存和 SWF 文件中这个图片占用的磁盘空间 ...

  3. SWT, JFace必须的jar包和有可能会用到的jar

    先附上一篇转载的, 转自CSDN, 原文地址:http://blog.csdn.net/nabber/article/details/1879511 如果阁下看到了这篇文章,估计你已经碰到了这样的困那 ...

  4. 揭开HTTP网络协议神秘面纱系列(二)

    HTTP报文内的HTTP信息 HTTP协议交互的信息被称为HTTP报文,请求端的HTTP报文叫做请求报文,响应端的叫做响应报文. HTTP为了提升传输速率,其在传输数据时,按照数据原样进行压缩传输,相 ...

  5. 统计学习方法笔记(KNN)

    k近邻法(k-nearest neighbor,k-NN) 输入:实例的特征向量,对应于特征空间的点:输出:实例的类别,可以取多类. 分类时,根据其k个最近邻的训练实例的类别,通过多数表决等方式进行预 ...

  6. Mysql导入数据库的方法

    mysql导入数据库的方法 | 浏览:41023 | 更新:2012-11-01 19:45 1 2 3 4 5 6 7 分步阅读 MySQL是一个中.小型关系型数据库管理系统,由瑞典MySQL AB ...

  7. 如何在 IIS 中设置 HTTPS 服务

    Windows Server2008.IIS7启用CA认证及证书制作完整过程 这篇文章介绍了如何安装证书申请工具: 如何在iis创建证书申请: 如何使用iis申请证书生成的txt文件,在工具中开始申请 ...

  8. Linux下安装软件的一般步骤

    目录 一.解析Linux应用软件安装包 二.了解包里的内容 三.搞定使用tar打包的应用软件 四.搞定使用rpm打包的应用软件 五.搞定使用deb打包的应用程序 一.解析Linux应用软件安装包(回目 ...

  9. php pdo预处理语句与存储过程

    很多更成熟的数据库都支持预处理语句的概念.什么是预处理语句?可以把它看作是想要运行的 SQL 的一种编译过的模板,它可以使用变量参数进行定制.预处理语句可以带来两大好处: 1.查询仅需解析(或预处理) ...

  10. Python缩进

    今天练习代码的时候发现一个问题,练习类,我在notepad++上写的代码运行后,复制到pycharm上运行然后报错,看代码 #---coding:utf-8--- #定义一个Person类然后实例化 ...