「js非同步處理」的推薦目錄:
- 關於js非同步處理 在 コバにゃんチャンネル Youtube 的精選貼文
- 關於js非同步處理 在 大象中醫 Youtube 的最讚貼文
- 關於js非同步處理 在 大象中醫 Youtube 的最讚貼文
- 關於js非同步處理 在 [問題] JavaScript 的非同步物件導向寫法- 看板Ajax - 批踢踢實業坊 的評價
- 關於js非同步處理 在 非同步 的評價
- 關於js非同步處理 在 Node.js 大入門家(3/9) 非同步處理| callback 的評價
- 關於js非同步處理 在 JavaScript 深入淺出Synchronous & Asynchronous 同步與 ... 的評價
- 關於js非同步處理 在 [Javascript]非同步的救星Promise 的評價
- 關於js非同步處理 在 [JS] Async and Await in JavaScript | PJCHENder 未整理筆記 的評價
- 關於js非同步處理 在 JavaScript非同步程式流程的處理,可用Promise而趨於直覺 ... 的評價
js非同步處理 在 大象中醫 Youtube 的最讚貼文
js非同步處理 在 大象中醫 Youtube 的最讚貼文
js非同步處理 在 非同步 的推薦與評價
瀏覽器所提供的計時器 setTimeout() 、 setInterval(); DOM 的事件監聽 addEventListener(); 網路請求資料Ajax 呼叫. JavaScript 的非同步處理 ... ... <看更多>
js非同步處理 在 Node.js 大入門家(3/9) 非同步處理| callback 的推薦與評價
JavaScript ! 初學者!新手! 這一段, 我們來學習Node.js 最有趣的非同步處理(asynchronous) 處理非同步的三大方法callback --- Promise --- async/await 語法一次學會 ... ... <看更多>
js非同步處理 在 [問題] JavaScript 的非同步物件導向寫法- 看板Ajax - 批踢踢實業坊 的推薦與評價
原本的程式實在是太亂了
引用JS檔前還要先指定一個Global Variable
結果現在出問題了 要同時處理多筆資料
打算全部砍掉重練 用OOP來寫
不過現在遇到了一個問題
因為這個Object 有利用AJAX 去取得一些資料
所以並不能隨call隨用 還要指定一個callback function
因為要考慮到錯誤處理的方式 和 UI 的動態顯示
所以可能需要兩個callback function
一個是用來存資料 一個是用來更新UI
(我想把這js和網頁頁面完全獨立開來,因此不能包在一起)
但是不知道各位前輩有什麼方法比較好去實做呢?
--
I'm not the only one,
To crash into the sun, and live to fight another day.
Like a super nova, that old life is over.
I'm here to stay. Now I'm gonna be,
Invincible.
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 140.113.244.14
感謝!! 今天又學到新東西了
deffered!!!!!!!!!
感動~~ 雖然還是沒解決
等等有空把全部的思路全部打上來
我現在遇到了一個問題
大概如下
<myscript.js>
function MyOJ(param)
{
this.predata = param
this.dataA = null // 等待ajax 取得資料
this.dataB = null //
}
MyOJ.prototype =
{
init: function()
{
this.getDataA()
}
getDataA: function()
{
return $.post(urlB,this.getDataB.bind(this))
},
getDataB: function(dataA) //ajax A的回傳資料
{
this.dataA = dataA
return $.post(urlC,this.initFinish.bind(this))
},
initFinish: function(dataB) //ajax B的回傳資料
{
var dtd = $.Deferred()
this.dataB = dataB
dtd.resolve()
return dtd
}
}
<MyHTML.html>
<script>
var a = new MyOJ(params)
a.getDataA().done( getA_Callback) //回報UI用
.fail( getA_Fail )
a.getDataB().done( getB_Callback) //回報UI用
.fail( getB_Fail)
a.initFinish.done( myInitFinish ) //模組已全部載入 可以使用了
a.init()
function myInitFinish()
{
$('#dataA').text(a.dataA) //保證有資料
$('#dataB').text(a.dataB) //保證有資料
}
</script>
意思就是
當程式呼叫 init 時, js 那邊開始進入取得資料的模式
同時我可以在外部掛載一些function 能讓UI知道下載的進度
不過紅字部分出了問題
因為Deferred物件要在執行後才會return
但是,我現在還沒init
而且這些function, 應該是給ajax完成後在內部才執行的(同時函數內參數就是回傳值)
雖然這段程式碼有嚴重錯誤
但是應該可以表現出我想要達到的效果了~~
麻煩各位大大指點迷津QQ...
※ 編輯: Fonger 來自: 61.230.168.152 (11/17 08:59)
※ 編輯: Fonger 來自: 61.230.168.152 (11/17 09:00)
... <看更多>