也就是说,不同的操作函数,操作符,JS将其放入事件队列是不一样的。。。

比如:

外部函数和内部函数,就是分两次放入事件循环的尾端的。

比如,多个操作符组成的链式操作,也有可能是放不同的操作批次进入事件循环链的。

因为下面代码中的输出就显示了异步事件循环在JS当中的体现。

好好体味了一个小时。

var test = function() {

    for(var i = 0; i < 5; i++) {
        console.log(i+ " test outter");

        (function(i) {
          setTimeout(function() {
            console.log(i);
        }, 2000);
        })(i);

    }

};

var test2 = function() {
    var ret = [];
     for(var i = 0; i < 5; i++) {
       console.log(i+ " test2 outter");
        (function(i) {
          ret[i] = function() {
          console.log(i + " test2 inner");
          return i;
        }
        })(i);
      }
    console.log(ret);
    return ret;
};

var test0 = test(), test1 = test2()[2]();
var test2 = test2()[2](), test3 = test();

  输出:

"0 test outter"
"1 test outter"
"2 test outter"
"3 test outter"
"4 test outter"
"0 test2 outter"
"1 test2 outter"
"2 test2 outter"
"3 test2 outter"
"4 test2 outter"
[function () {
        window.runnerWindow.proxyConsole.log(i + " test2 inner");
        return i;
      }, function () {
        window.runnerWindow.proxyConsole.log(i + " test2 inner");
        return i;
      }, function () {
        window.runnerWindow.proxyConsole.log(i + " test2 inner");
        return i;
      }, function () {
        window.runnerWindow.proxyConsole.log(i + " test2 inner");
        return i;
      }, function () {
        window.runnerWindow.proxyConsole.log(i + " test2 inner");
        return i;
      }]
"2 test2 inner"
"0 test2 outter"
"1 test2 outter"
"2 test2 outter"
"3 test2 outter"
"4 test2 outter"
[function () {
        window.runnerWindow.proxyConsole.log(i + " test2 inner");
        return i;
      }, function () {
        window.runnerWindow.proxyConsole.log(i + " test2 inner");
        return i;
      }, function () {
        window.runnerWindow.proxyConsole.log(i + " test2 inner");
        return i;
      }, function () {
        window.runnerWindow.proxyConsole.log(i + " test2 inner");
        return i;
      }, function () {
        window.runnerWindow.proxyConsole.log(i + " test2 inner");
        return i;
      }]
"2 test2 inner"
"0 test outter"
"1 test outter"
"2 test outter"
"3 test outter"
"4 test outter"
0
1
2
3
4
0
1
2
3
4

  

如何观察JS的事件队列的执行划分的更多相关文章

  1. JS引擎线程的执行过程的三个阶段(二)

    继续JS引擎线程的执行过程的三个阶段(一) 内容, 如下: 三. 执行阶段 1. 网页的线程 永远只有JS引擎线程在执行JS脚本程序,其他三个线程只负责将满足触发条件的处理函数推进事件队列,等待JS引 ...

  2. JS的解析与执行过程

    JS的解析与执行过程 全局中的解析和执行过程 预处理:创建一个词法环境(LexicalEnvironment,在后面简写为LE),扫描JS中的用声明的方式声明的函数,用var定义的变量并将它们加到预处 ...

  3. js中的延迟执行和定时执行

    在js中,延迟执行函数有两种,setTimeout和setInterval,用法如下: function testFunction(){Console.log('hovertree.com');} s ...

  4. [转]js中confirm实现执行操作前弹出确认框的方法

    原文地址:http://www.jb51.net/article/56986.htm 本文实例讲述了js中confirm实现执行操作前弹出确认框的方法.分享给大家供大家参考.具体实现方法如下: 现在在 ...

  5. JS匿名函数自执行函数

    JS匿名函数自执行函数:(function(){})();(function(){}) 这是一个函数,函数后面接(),则是调用函数 比如(function(arg){console.log(arg); ...

  6. js判断浏览器类型 js判断ie6不执行

    js判断浏览器类型 $.browser  对象 $.browser.version 浏览器版本 var binfo = ''; if ($.browser.msie) { binfo = " ...

  7. JS延时一秒执行

    //JS延时一秒执行 setTimeout(function(){ window.history.go(0); }, 1000);

  8. js解析器的执行原理

    首先看一段代码 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> < ...

  9. JS引擎线程的执行过程的三个阶段(一)

    浏览器首先按顺序加载由<script>标签分割的js代码块,加载js代码块完毕后,立刻进入以下三个阶段,然后再按顺序查找下一个代码块,再继续执行以下三个阶段,无论是外部脚本文件(不异步加载 ...

随机推荐

  1. Android 手势水平监听判断

    package com.zihao.ui; import com.zihao.R; import android.os.Bundle; import android.app.Activity; imp ...

  2. js 函数前的+号

    不知啥时候起,函数的闭包需要增加+才能立即执行了. 不加反而报语法错.orz +function() { console.log("Foo!"); }(); 输出: Foo!< ...

  3. git分支管理策略

    http://www.ruanyifeng.com/blog/2012/07/git.html https://www.digitalocean.com/community/tutorials/how ...

  4. sone2(未完成)

    先留个半完成代码 边看论文边看题解写的...难受.. #include<cstdio> #include<cstring> namespace utils{ inline in ...

  5. SQL Server 2008 R2 Developer (x86, x64, ia64) – DVD (Chinese-Simplified)

    http://blog.sina.com.cn/s/blog_4aedf6370101j9tz.html 1. SQL Server 2008 R2 Developer (x86, x64, ia64 ...

  6. ios NSURLSession completeHandler默认调用quque

    注意 , [[NSURLSession sharedSession] dataTaskWithRequest:request completionHandler:^(NSData *data, NSU ...

  7. java sleep() 、yield()

    1.sleep() 使当前线程(即调用该方法的线程)暂停执行一段时间,让其他线程有机会继续执行,但它并不释放对象锁.也就是说如果有synchronized同步快,其他线程仍然不能访问共享数据.注意该方 ...

  8. 7.django之自定义分页记录

    只是大概记录下步骤: 1.表结构: class UserProfile(models.Model): ''' 用户表 ''' user = models.OneToOneField(User,verb ...

  9. storyboard在ios模拟器无法显示的问题

    一.问题描述 1.在原有项目新建一个名称为test的storyboard类型的文件. 2.test.storyboard添加View Controller,并设置View Controller下Vie ...

  10. LINQ查询返回DataTable类型

    个人感觉Linq实用灵活性很大,参考一篇大牛的文章LINQ查询返回DataTable类型 http://xuzhihong1987.blog.163.com/blog/static/267315872 ...