大概是這樣的:
準備用react-saga做為異步方案,但是由于是React-Native項目,
在很多請求成功后需要在視圖層組件內(nèi)調(diào)用一些原生接口,
所以需要視圖層能知道什么時候異步任務(wù)結(jié)束,以及異步的處理結(jié)果。
以前在web端用的 dva 框架, 有一個特點就是當dispatch一個異步effect的時候, 會返回promise對象,然后在effect中返回處理結(jié)果, 視圖層就可以知道異步拿到的結(jié)果。
現(xiàn)在直接用的redux-saga,有沒有什么方案能實現(xiàn)這種特性?
目前已經(jīng)找到了解決的方案,感謝樓上這位大兄弟 @dablwow80 給的參考,
在這個基礎(chǔ)上寫了自己的處理,大概是這么個意思:
// 這個是我所有頁面的基類, 最終所有頁面都繼承這個
// 封裝這么一個方法 _dispatch,代替原本的dispatch
class Page extends React.Component {
_dispatch = (action) => {
return new Promise((resolve, reject) => {
this.props.dispatch({
type: action.type,
payload: {
...action.payload,
resolve,
reject,
},
})
})
}
}
// 然后是具體頁面上, 使用這個方法
class BootStrap extends Page {
render() {
return ...
}
componentDidMount() {
this.isLogin()
}
isLogin = async () => {
await this._dispatch({ type: 'USER_ISLOGIN' })
console.log('complete')
SplashScreen.hide() // 視圖層在請求完成后需要執(zhí)行的其他操作
}
}
// saga 里面,只要在異步完成后執(zhí)行resolve, reject就可以了
function* userIsLogin({ payload }) {
const { resolve } = payload
const user = yield call(fetch_user)
// ... other
yield fork(resolve, user)
}
這就是最簡單的一個栗子, 實際會有很多類似的場景, 需要在dispatch發(fā)出后,第一時間知道異步何時完成, 然后調(diào)用原生接口,或者其他組件方法, 而不能只依靠redux里傳出來的props數(shù)據(jù)更新
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內(nèi)教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復興的升級產(chǎn)業(yè)鏈。利用北京大學優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓領(lǐng)域的先行者
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務(wù)負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。