当前位置: 首页 > news >正文

宣传型网站iis打开网站变成下载

宣传型网站,iis打开网站变成下载,河北建设厅网站修改密码在哪,wordpress 值班功能宏任务和微任务 JS为微任务和宏任务简单介绍任务执行顺序例子任务执行顺序简单例子 关于new Promise实例化过程的例子 JS为微任务和宏任务简单介绍 js是单线程的,但是分同步异步微任务和宏任务皆为异步任务,它们都属于一个队列宏任务一般是:…

宏任务和微任务

    • JS为微任务和宏任务简单介绍
      • 任务执行顺序例子
      • 任务执行顺序简单例子
    • 关于new Promise实例化过程的例子

JS为微任务和宏任务简单介绍

  1. js是单线程的,但是分同步异步
  2. 微任务和宏任务皆为异步任务,它们都属于一个队列
  3. 宏任务一般是:script、setTimeout、setInterval、postMessage
  4. 微任务:Promise.then ES6
  5. 先执行同步再执行异步,异步遇到微任务,先执行微任务,执行完后如果没有微任务,就执行下一个宏任务,如果有微任务,就按顺序一个一个执行微任务

任务执行顺序
同步任务 ——> 异步任务中微任务 ——> 异步任务中宏任务

任务执行顺序例子

function doFoo(fn) {this.code = 404;fn();
}function f() {setTimeout(() => {console.log(">>>" + this); // >>>[object window],语句3this.code = 401; // 语句4}, 0)console.log( this.code ); // 404,语句2
}let obj = {code: 200,foo: f
};var code = 500;doFoo( obj.foo ); // 语句1
setTimeout(()=>{console.log(obj.code)}, 0); // 200,语句5
setTimeout(()=>{console.log(window.code)}, 0); // 401,语句6

分析

  1. 按照先同步再异步的顺序,从上往下编译执行,第一个执行doF( obj.foo )任务,将obj.foo作为参数传入到函数doFoo当中,此时作为调用者的对象还是window,doFoo函数中this.code = 404;将window对象下的code值修改为404
  2. 之后doFoo函数继续调用 f() 函数,f()函数中的setTimeout()是宏任务,先放入宏任务列表里,不执行,反而直接执行后面的 console.log( this.code ); 此时调用该函数的对象还是window,所以打印出404,继续接下来的任务,将两个setTimeout()都放入宏任务列表
  3. 执行第一个放入的setTimeout()任务,执行其中this.code=401,将window对象下的code的值又修改为401
  4. 执行第二个放入的setTimeout()任务,执行console.log(obj.code),整个过程中obj对象的code一直没被修改,所以还是200
  5. 执行第三个放入的setTimeout()任务,执行console.log(window.code),打印出401

任务执行顺序简单例子

console.log(1)
setTimeout(function() {console.log(2)
}, 0)
const p = new Promise((resolve, reject) => {resolve(4)
})
p.then(data => {console.log(data)
})
console.log(3)
//1,3,4,2

分析

  1. 先同步再异步,从上往下编译执行,首先遇到同步任务console.log(1);输出1;
  2. 接着遇到setTimeout 异步宏任务,放入宏任务队列中;
  3. 接着遇到 Promise,new Promise在实例化的过程中所执行的代码都是同步进行的,但由于new Promise没有输出事件,所以无事发生。
  4. 接着遇到.then,then是异步微任务,不执行,加入到异步微任务列表;
  5. 遇到同步任务console.log(3);输出3;
  6. 主线程中同步任务执行完,从微任务队列中取出任务到主线程中,先取出作为微任务的.then,p.then 输出4,微任务执行完毕,微任务队列为空;
  7. 开始执行宏任务setTimeout 输出2,宏任务队列为空;

重点注意new Promise在实例化的过程中所执行的代码都是同步进行的

关于new Promise实例化过程的例子

console.log(1)
setTimeout(function() {console.log(2)new Promise(function(resolve) {console.log(3)resolve()}).then(function() {console.log(4)})
})new Promise(function(resolve) {console.log(5)resolve()
}).then(function() {console.log(6)
})setTimeout(function() {console.log(7)new Promise(function(resolve) {console.log(8)resolve()}).then(function() {console.log(9)})
})
console.log(10)
//1,5,10,6,2,3,4,7,8,9

分析

  1. 先同步再异步,从上往下编译执行,首先遇到同步任务console.log(1);输出1;
  2. 遇到setTimeout 异步宏任务,放入宏任务队列中;
  3. 遇到 Promise,new Promise在实例化的过程中所执行的代码都是同步进行的,所以输出5,
  4. 所以接着遇到.then;.then,异步微任务,被分发到微任务Event Queue中;
  5. 遇到setTimeout,异步宏任务;放入宏任务队列中;
  6. 遇到同步任务console.log(10);输出10,主线程中同步任务全部执行完;
  7. 同步任务全部执行完,从微任务队列中取出任务到主线程中,输出6;
  8. 在从宏任务队列中取出任务到主线程中,执行第一个setTimeout,输出2,3,4(在宏任务中执行同步,同步,异步微任务);
  9. 在执行第二个setTimeout,输出7,8,9(和8同理);
http://www.yayakq.cn/news/719392/

相关文章:

  • 深圳网站建设公司佰达建筑网片钢筋网片
  • 公司网站制作服务策划咨询
  • 专业的佛山网站建设微信小程序与公众号的区别
  • 有没有安全一点的网站wordpress免费采集器
  • 怎么修改网站默认首页东海县建网站
  • 阿里云搭建网站教程巴中区建设局网站
  • 自己建网站的流程网站建设仿站企业公司
  • html网页留言板代码湘潭seo优化公司
  • 网站建设网络公关台州网站制作费用
  • 东莞做公司网站wordpress访问速度太慢
  • 百度怎样建立一个网站深圳宝安区繁华吗
  • 制作h5网站开发wordpress 多用户商城主题
  • 广告手机网站制作wordpress4.2
  • 平面设计案例网站天猫网站建设的目的
  • 深圳 建设银行国际互联网站建筑人才网上传不了论文
  • 网站的模糊搜索怎么做做网站费用分几块
  • 刷网站关南京传销是以网站开发
  • wordpress有没有翻书的主题网络seo关键词优化技巧
  • 临沂网站建设费用网站建设与维护心得
  • 网站关闭多久排名会下降wordpress主题模块添加
  • 网站开发设计软件网页设计与制作教程电子版pdf
  • 商城网站建设论坛网络规划与设计毕设
  • 深圳网站建设叶林一流本科专业建设点网站
  • 永州做网站公司wordpress获取自定义类型文章
  • 如何做ps4的游戏视频网站广州企业自助建站
  • 企业网站无线端怎么做小程序模板源码免费
  • 宁波网站推广制作wordpress ss
  • 关于php网站建设的优秀论文公众号开发神器
  • 网站开发后台数据怎么来网站策划厂
  • 网站建设经典教材电子科技产品网站建设