從應(yīng)用角度看ReativeX

這篇從我個人的角度聊聊ReactiveX這種思想的應(yīng)用場景。

首先不論MVVM的使用場景,我也沒有特別豐富的MVVM的使用經(jīng)驗。那么什么場景更加適合呢?

請求

如果只是單獨的請求,那么也沒有Reactive什么事情,但是當(dāng)多個請求的時候,那么問題就來了。

多個請求就涉及到多次返回,那么如何組織這多次返回呢?可能有些場景要求按照發(fā)請求的順序返回,有些場景可能僅需要任一個請求返回,又或者有些需要所有都返回的時候才觸發(fā)回調(diào),甚至可能有些請求存在依賴。

如何比較好的處理這些需求,那么Reactive本身就給我們一個很好的解決方案,可以說就是為了處理這種場景而生的。

流程

很多時候,我們的一個流程會非常長,比如注冊、首次登陸等等,而這些流程可能中間的某些步驟是可以復(fù)用的,然而很多不同的步驟所需要的參數(shù)可能也會稍有不同,那么如何表示這種流程比較好呢?

把每一個步驟都做成Signal,那么這個問題就非常簡單的解決了,不管流程的走向和分支是怎么樣的,Reactive都能很好的解決,也不需要每一步都精心做好回調(diào),然后把事件傳遞的到處都是。

總結(jié)

這就不得不提一下monad這個概念了,只要符合pure function操作的所有行為,其實都可以定義為signal,并且利用各種組合來解決一定的時序問題。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容