通过实验窥探javascript的解析执行顺序
简介
javascript是一种解释型语言,它的执行是自上而下的。但是各浏览器对于【自上而下】的理解是有细微差别的,而代码的上下游也就是程序流对于程序正确运行又是至关重要的。所以我们有必要深入理解js的执行顺序。为此,我设计了如下八个实验来获得最确切的结果。
实验
- <script type="text/javascript">
- //实验一:
- function t(a)
- {
- alert("[t(a)]a:" + a);
- }
- function t(a, b)
- {
- alert("[t(a, b)]a:" + a + ", b:" + b);
- }
- t(1);
- //结果:
- //[t(a, b)]a:1, b:undefined
- //实验二:
- function t(a, b)
- {
- alert("[t(a, b)]a:" + a + ", b:" + b);
- }
- function t(a)
- {
- alert("[t(a)]a:" + a);
- }
- t(1);
- //结果:
- //[t(a)]a:1
- //实验三:
- function t(a)
- {
- alert("[t(a)]a:" + a);
- }
- function t(a, b)
- {
- alert("[t(a, b)]a:" + a + ", b:" + b);
- }
- t(1, 2);
- //结果:
- //[t(a, b)]a:1, b:2
- //实验四:
- function t(a, b)
- {
- alert("[t(a, b)]a:" + a + ", b:" + b);
- }
- function t(a)
- {
- alert("[t(a)]a:" + a);
- }
- t(1, 2);
- //结果:
- //[t(a)]a:1
- //实验五
- function t(a)
- {
- alert("[t(a)]a:" + a);
- }
- t(1);
- function t(a, b)
- {
- alert("[t(a, b)]a:" + a + ", b:" + b);
- }
- //结果:
- //[t(a, b)]a:1, b:undefined
- //实验六
- function t(a)
- {
- alert("[t(a)]a:" + a);
- }
- t(1, 2);
- function t(a, b)
- {
- alert("[t(a, b)]a:" + a + ", b:" + b);
- }
- //结果:
- //[t(a, b)]a:1, b:2
- //实验七
- function t(a, b)
- {
- alert("[t(a, b)]a:" + a + ", b:" + b);
- }
- t(1);
- function t(a)
- {
- alert("[t(a)]a:" + a);
- }
- //结果:
- //[t(a)]a:1
- //实验八
- function t(a, b)
- {
- alert("[t(a, b)]a:" + a + ", b:" + b);
- }
- t(1, 2);
- function t(a)
- {
- alert("[t(a)]a:" + a);
- }
- //结果:
- //[t(a)]a:1
- </script>
后记
定义javascript函数时,函数名是函数对象的标识,参数数量只是这个函数的属性。靠定义参数数量不同的函数实现重载是不行的。
调用函数时,js通过函数名找到对应的函数对象,然后根据函数定义时的参数,和表达式参数列表按顺序匹配,多余的参数舍去,不够的参数按undefined处理,然后执行函数代码。
所以定义函数时,通常把必选参数放在参数列表最前面,可选参数放在必选参数后面。
注意事项
一、上述八个实验的结果是经过360浏览器(版本/内核:6.3.1.142/21.0.1180.89)和火狐浏览器(版本:27.0.1)运行得出的。
二、上述八个实验是相互独立的,请分别单独运行以得到正确的结果。
通过实验窥探javascript的解析执行顺序的更多相关文章
- JavaScript程序的执行顺序
JavaScript程序的执行顺序:同步==>异步==>回调 同步是阻塞模式,异步是非阻塞模式. 同步就是指一个进程在执行某个请求的时候,若该请求需要一段时间才能返回信息,那么这个 ...
- Javascript加载执行顺序
本文主要内容 一.不同位置的script标签执行顺序 二.document.ready和window.onload的区别 一.不同位置的script标签执行顺序 整个加载的过程从解析头部开始,比如ht ...
- JavaScript Alert 函数执行顺序问题
* { color: #3e3e3e } body { font-family: "Helvetica Neue", Helvetica, "Hiragino Sans ...
- html 和 javascript 的相关执行顺序
1.dom 树和 js 的加载顺序 http://blog.csdn.net/jdsxzhao/article/details/44646463 2. jquery中各个事件执行顺序如下: https ...
- JavaScript代码内部执行顺序
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- JavaScript执行顺序分析
之前从JavaScript引擎的解析机制来探索JavaScript的工作原理,下面我们以更形象的示例来说明JavaScript代码在页面中的执行顺序.如果说,JavaScript引擎的工作机制比较深奥 ...
- javascript的执行顺序(转载)
之前从JavaScript引擎的解析机制来探索JavaScript的工作原理,下面我们以更形象的示例来说明JavaScript代码在页面中的执行顺序.如果说,JavaScript引擎的工作机制比较深奥 ...
- 浏览器环境下JavaScript脚本加载与执行探析之代码执行顺序
本文主要基于向HTML页面引入JavaScript的几种方式,分析HTML中JavaScript脚本的执行顺序问题 1. 关于JavaScript脚本执行的阻塞性 JavaScript在浏览器中被解析 ...
- <script>标签的加载解析执行
转自原文 <script>标签的加载解析执行 看了很多网上的文章,都是大同小异.总结一下.内部原理还没有搞清楚,有机会再学习. 一.<script>标签的加载解析执行顺序 ht ...
随机推荐
- Android_ADB 常用 shell命令 和 sqlite3 简单增删改查
今天学习了一个ADB的常用命令.接下来简单使用几个常用ADB shell 命令. 首先我们得明白什么是adb.exe ADB -Android Debug Bridge, 是 Android sdk ...
- 构建ASP.NET网站十大必备工具(1)
最近使用ASP.NET为公司构建了一个简单的公共网站(该网站的地址:http://superexpert.com/).在这个过程中,我们使用了数量很多的免费工具,如果把构建ASP.NET网站的必备工具 ...
- construction of tuples containing 0 or 1 items
[construction of tuples containing 0 or 1 items] the syntax has some extra quirks to accommodate the ...
- 如何异步创建文件夹(node)
模块fs作为node的核心模块之一,支持本地文件操作的接口,几乎对于所有的操作都提供同步和异步两种方案.例如,创建文件夹有mkdir和mkdirSync.不论对于mkdir还是mkdirSync,都需 ...
- easyUI删除行的操作
columns: [[ { field: 'KeyContent', title: '关键词' }, { field: 'ProductType', title: "用品/配件", ...
- textarea 怎么固定大小,不让调整
1:彻底禁用拖动(推荐) resize: none; 2:只是固定大小,右下角的拖动图标仍在 width: 200px; height: 100px; max-width: 200px; max-he ...
- R语言--数据预处理
一.日期时间.字符串的处理 日期 Date: 日期类,年与日 POSIXct: 日期时间类,精确到秒,用数字表示 POSIXlt: 日期时间类,精确到秒,用列表表示 Sys.date(), date( ...
- 使用Resource Owner Password Credentials Grant授权发放Token
对应的应用场景是:为自家的网站开发手机 App(非第三方 App),只需用户在 App 上登录,无需用户对 App 所能访问的数据进行授权. 客户端获取Token: public string Get ...
- (Python)序列
本节将学习一些循环序列的方法已经序列的大小比较规则 1.循环序列的方法 如果我们想同时循环打印一个列表的index和value,我们可以用enumerate(list) 函数 >>> ...
- null 与 string.IsNullOrEmpty 区别
!= null 就是不为null!string.IsNullOrEmpty 不是null且不是""(string.Empty) -----------Response: != n ...