您好,登錄后才能下訂單哦!
這篇文章主要介紹“JavaScript實現異步傳輸的原理是什么”,在日常操作中,相信很多人在JavaScript實現異步傳輸的原理是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”JavaScript實現異步傳輸的原理是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
一、瀏覽器
在我們的開發中,在瀏覽器端中的JavaScript可以實現兩個比較重要的接口,這兩個接口分別是定時器和ajax請求
定時器:
對于定時器,當它被執行的時候,我們的瀏覽器會進行執行定時計數,而且在定時事件觸發之后會把事件推到我們的JavaScript事件中,只有當JavaScript主線程同步完成之后才會到時間事件進行執行,所以JavaScript的定時器并不是準時觸發的。
Ajax:
那么我們的Ajax請求和我們的定時器是一樣的,他們同樣是通過委托瀏覽器來進行執行任務,在Ajax中是由于瀏覽器中的http請求線程之后發起服務請求,在得到請求之后從而完成事件,然后再將回調函數推入到我們的事件隊列中進行等待。
二、Node JS 端
對于Node JS的異步實現和瀏覽器實現是有所不同的,在Node JS 中的Libuv 為我們提供了很多能力,其中包含:跨平臺、線程池、事件池、異步I/O 等等。不僅如此在Libuv中還為上一層的Node.js提供了統一的API調用,這就讓我們在使用的時候不需要去考慮平臺之間的差距,而且還可以做到隱藏了底層的實現,對于Libuv來說它本身就是異步和時間驅動的,所以當我們將I/O操作的請求傳送給Libuv之后,就會開啟線程來執行我們的I/O的調用,后面在傳給我們的JavaScript從而進行最后的處理。
發起I/O調用:
1、我們在使用的使用是讓用戶通過 Javascript 代碼調用 NodeJS 核心模塊,將參數和回調傳入核心模塊。
2、 在NodeJS中我們需要通過 核心模塊將傳入參數和回調封裝為一個請求對象。
3、 將這個請求對象推入到I/O線程池中等待執行 J。
4、avascript 發起的異步調用結束,Javascript 線程繼續執行后續操作 。
執行回調:
1、異步任務完成之后,會將結果存放在請求對象的 result 屬性上,并發出操作完成通知 。
2、每次事件循環時會檢查 I/O 線程池中是否存在已經完成的 I/O 操作,如果有就將請求事件加入到I/O觀察者隊列當中(事件隊列),之后當作事件處理 。
3、處理I/O觀察者事件時,會將之前封裝在請求對象中的回調函數取出,并將 result 參數傳入執行,以完成 Javascript 回調的目的 。
到此,關于“JavaScript實現異步傳輸的原理是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。