站長資訊網
最全最豐富的資訊網站

javascript實現異步的方法有哪些

方法:1、利用setTimeout;2、利用setImmediate;3、利用requestAnimationFrame;4、通過監聽“new Image”加載狀態來實現;5、通過監聽script加載狀態來實現;6、利用Message等等。

javascript實現異步的方法有哪些

本教程操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

原生javascript實現異步的方式:

1、setTimeout:這個是最簡單的

setTimeout( function() {     console.log(1); }); console.log(2);

2、setImmediate :IE10添加的新功能,專門用于解放ui線程。IE10以下及其他瀏覽器不支持

setImmediate(function(){     console.log(1); }); console.log(2);

3、requestAnimationFrame :HTML5/CSS3時代新產物,專門用于動畫。低級瀏覽器不支持

var asynByAniFrame = (function(){     var _window = window,     frame = _window.requestAnimationFrame             || _window.webkitRequestAnimationFrame             || _window.mozRequestAnimationFrame             || _window.oRequestAnimationFrame             || _window.msRequestAnimationFrame;     return function( callback ) { frame( callback ) }; })();  asynByAniFrame(function(){     console.log(1); }) console.log(2);

4、監聽new Image加載狀態:通過加載一個data:image數據格式的圖片,并監聽器加載狀態實現異步。

  盡管部分瀏覽器不支持data:image圖片數據格式,但仍然可以觸發其onerror狀態實現異步,但IE8及以下對data:image數據格式的圖片,onerror為同步執行

function asynByImg( callback ) {     var img = new Image();     img.onload = img.onerror = img.onreadystatechange = function() {         img = img.onload = img.onerror = img.onreadystatechange = null;         callback();      }     img.src = "data:image/png,"; } asynByImg(function(){     console.log(1); }); console.log(2);

5、監聽script加載狀態

  原理同new Image是一樣的,生成一個data:text/javascript的script,并監聽其加載狀態實現異步。

  盡管部分瀏覽器不支持data:text/javascript格式數據的script,但仍然可以觸發其onerror、onreadystatechange事件實現異步。

var asynByScript = (function() {     var _document = document,         _body = _document.body,         _src = "data:text/javascript,",         //異步隊列         queue = [];     return function( callback ) {             var script = _document.createElement("script");             script.src  = _src;             //添加到隊列             queue[ queue.length ] = callback;             script.onload = script.onerror = script.onreadystatechange = function () {                 script.onload = script.onerror = script.onreadystatechange = null;                 _body.removeChild( script );                 script = null;                 //執行并刪除隊列中的第一個                 queue.shift()();             };             _body.appendChild( script );         }      })();  asynByScript( function() {     console.log(1); } ); console.log(2);

6、Message:html5新技能,通過監聽window.onmessage事件實現,然后postMessage發送消息,觸發onmessage事件實現異步

var asynByMessage = (function() {         //異步隊列         var queue = [];         window.addEventListener('message', function (e) {             //只響應asynByMessage的召喚             if ( e.data === 'asynByMessage' ) {                 e.stopPropagation();                 if ( queue.length ) {                     //執行并刪除隊列中的第一個                     queue.shift()();                 }             }         }, true);         return function( callback ) {             //添加到隊列             queue[ queue.length ] = callback;             window.postMessage('asynByMessage', '*');         };     })();  asynByMessage(function() {     console.log(1); }); console.log(2);

7、Promise: ES6的新技能,具有異步性質

var asynByPromise = (function() {         var promise = Promise.resolve({                 then : function( callback ) {                     callback();                 }             });         return function( callback ) {                     promise.then(function(){                         callback();                     })                 };     })(); asynByPromise(function() {     console.log(1); }); console.log(2);

贊(0)
分享到: 更多 (0)
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
日韩一级视频在线观看播放| 国产主播精品在线| 久久91精品综合国产首页| 日韩影片在线观看| 国产成人一区二区三区精品久久| 老司机无码精品A| 国产精品第一区揄拍| 精品久久久久香蕉网| 亚洲精品视频在线观看免费| 99久久免费看国产精品| 久久国产精品麻豆映画| 国产精品乱码高清在线观看| 国精品无码一区二区三区左线| 99re这里只有精品6| 久久久久久国产精品美女| 国产福利精品视频自拍| 亚洲一区无码精品色| 一区二区不卡久久精品| 色婷婷噜噜久久国产精品12p| 日韩一区二区三区电影在线观看| 日韩插啊免费视频在线观看 | 久久久无码精品亚洲日韩蜜臀浪潮 | 青青热久久国产久精品| 国产伦精品一区二区三区四区 | 国产精品社区在线观看| 精品69久久久久久99| 在线91精品亚洲网站精品成人| 精品久久久久久久99热| 国产真实乱子伦精品| 日韩蜜芽精品视频在线观看| 日韩亚洲Av人人夜夜澡人人爽| 久久久久久久久无码精品亚洲日韩 | 久久成人国产精品免费软件 | 中日韩产精品1卡二卡三卡| 国产日韩在线视看高清视频手机| 亚洲日韩VA无码中文字幕| 亚洲日韩乱码中文无码蜜桃臀网站 | 中文字幕精品三区无码亚洲 | 91麻豆精品国产自产在线观看亚洲| 香蕉在线精品视频在线观看2| 东京热TOKYO综合久久精品|