首页 > 代码库 > JS中事件的执行顺序

JS中事件的执行顺序

项目需求页面一键发布,下面是一个简单demo:  

html:

  <button id="send">提交</button>
  <table id="mytable"></table>

  js:

   $(function(){
     $(‘#send‘).click(function(){
      startTime = new Date();//设置开始时间
      $.ajax({
        type: "GET",
        url: "data.json",
        data: {},
        dataType: "json",
        success: function(data){
        var _html = ‘‘;
        for(var i= 0,len = data.chrildReslut.length;i<len;i++){
          _html += ‘<tr><td id="‘+data.chrildReslut[i].id+‘">0%</td><tr>‘
        };
          $(‘#mytable‘).html(_html);
          forFn(data.chrildReslut);
      }
  });
  });
 });

  

  var i = 0;
  function forFn(data){
    if(i < data.length && data[i].reslut === ‘Y‘){
      process(data[i].id,0,100,data);
      i++;
    }else if(i < data.length){
      var number = parseInt(RandomNum(1,99));
      process(data[i].id,0,number,data);
      i++;
    }
  }

  function RandomNum(Min,Max){
    var Range = Max - Min;
    var Rand = Math.random();
    var num = Min + Math.round(Rand * Range);
    return num;
  };

  function process(id,start,end,data){
    var interval = setInterval(function(){
      start+=8;
      $(‘#‘+ id).html(start+‘%‘);
      if(start === end || start > end){
        clearInterval(interval);//关闭定时器
          $(‘#‘+ id).html(end+‘%‘);
          forFn(data);
        }
      },100)
  };

  结语:Javascript语言的执行环境是"单线程",但是这种模式后面的耗时较长,页面出现假死状态。为了解决这个问题,Javascript语言将任务的执行模式分成两种:同步(Synchronous)和异步(Asynchronous)。"同步模式"就是上一段的模式,后一个任务等待前一个任务结束,然后再执行,程序的执行顺序与任务的排列顺序是一致的、同步的;"异步模式"则完全不同,每一个任务有一个或多个回调函数(callback),前一个任务结束后,不是执行后一个任务,而是执行回调函数,后一个任务则是不等前一个任务结束就执行,所以程序的执行顺序与任务的排列顺序是不一致的、异步的。"异步模式"非常重要。在浏览器端,耗时很长的操作都应该异步执行,避免浏览器失去响应,最好的例子就是Ajax操作。在服务器端,"异步模式"甚至是唯一的模式,因为执行环境是单线程的,如果允许同步执行所有http请求,服务器性能会急剧下降,很快就会失去响应。本文参考阮一峰老师Javascript异步编程的4种方法 http://www.ruanyifeng.com/blog/2012/12/asynchronous%EF%BC%BFjavascript.html。

 

  

JS中事件的执行顺序