国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

淺談React Native 傳參的幾種方式(小結)

2024-05-06 16:51:11
字體:
來源:轉載
供稿:網友

在React Native 中由于業務的需要, 我們往往要在諸多的頁面間,組件之間做一些參數的傳遞與管理, 在這里我總結了幾大經過驗證,穩定好用的方式給大家

React Navigation 導航傳值

推薦指數: ♥ ♥ ♥ ♥ ♥

適用范圍: 相互跳轉的頁面間傳值

兼容性: IOS/Android

原理: React Navigation 為頁面的 props 上掛載了 navigation 對象, 可用來做路由跳轉,在做頁面跳轉時可以攜帶參數/回調方法前往目標頁面, 從而達到傳參的目的

說明: 這是官方推薦,也是我們在業務開發中用得最多,最為推崇的一種傳參方式, 思想與 web 在 querystring 上帶參跳轉類似,只是實現方式略微不同, 舉例

導航傳值即可正向傳值,也可反向傳值 例如 A->B 是正向傳值, 而B->A 則是反向傳值

正向傳值:

A頁面跳轉向B頁面, 在組件內通過訪問 this.props.navigation.navigate('B', { 

 type: 'list',    callback:data => { console.log('data in callback: ', data); } });

在B頁面 就能在組件的生命周期函數中拿到值

 componentWillMount() { const { state: { params: { type, callback }, goBack }} = this.props.navigation; console.log('type: ', type); // type 'list' }

反向傳值: 在反回上一個頁面時, 手動調用callback, 并給其傳參, 再調用 goBack 方法, 即可達到目的

還是上面的例子:

當從B返回A的時候

 goBackToPageA: () => { const { state: { params: { type, callback }, goBack }} = this.props.navigation; callback({ id: '123', message: type + ' really?'}); goBack(); } goBackToPageA();

 回到A頁面后

'data in callback: ', { id: '123', message: 'list really?'});

 也即callBack 中的 data 參數就是 { id: '123', message: 'list really?'}

DeviceEventEmitter 觸發事件并傳值

推薦指數: ♥ ♥ ♥ ♥

適用范圍: 頁面間傳值/組件間傳值

兼容性: IOS/Android

原理: 利用 React Native 包中提供的 DeviceEventEmitter 模塊訂閱事件,觸發事件,并能同時傳值

說明: DeviceEventEmitter 從名字就能知道他是基于事件訂閱的機制來進行傳值的, 當訂閱某種事件后, 觸發的時候會調用訂閱事件的回調, 并能把值傳送過去, 并且在同頁面內的組間件, 不同頁面間都可以傳值, 但前提是頁面還未被銷毀(銷毀后事件的訂閱會取消), 例如:

 DeviceEventEmitter.addListener('warning_event', (data) => { console.log('data: ', data);}) DeviceEventEmitter.emit('warning_event', { name: 'Mega Galaxy'}); // data: { name: 'Mega Galaxy' }

在emit(觸發)事件后, 回調函數的入參就變成了我們所傳遞的 { name: 'Mega Galaxy'}, 

也可不傳值,不傳值時 callback 的入參就是 undefined

缺點: 本質是對自定義事件的監聽與觸發, 當頁面邏輯復雜時,代碼會相對變大, 維護成本變高, 且監聽過多會造成性能問題, 還有一點就是在頁面銷毀時必須移除監聽: 如果忘記移除監聽會怎么樣? 那emit 一次的時候, 會多響應一次你加上去的監聽

componentDidMount() { this.eventHandler = DeviceEventEmitter.addListner('event_name', callback);}componentWillUnmount() { this.eventHandler.remove();}

個人建議: 在梳理清楚頁面邏輯后,合理使用

AsyncStorage Key-Value 式的存儲傳參

推薦指數: ♥ ♥ ♥ ♥

適用范圍: 跨頁面 跨組件的任性傳參

兼容性: IOS/Android

原理: 利用類似 web 中 localStorage 的思想,將參數/數據存放在 AsyncStorage中,在需要的地方再取出來

說明: localStorage 在 web 中的實用性 與 受歡迎程度大家是知道的, AsyncStorage其實就是 rn 版的 localStorage, 略微不同的是它是異步的,只返回 Promise, 所以與 async/await 結合會非常好用

···

在A頁面

saveOrderData = async () => { try { const orderData = [{ id: 1, data: []}, { id: 2, data: []}] await AsyncStorage.setItem('Order_data_cache', JSON.stringify(orderData )); } catch (error) { // Error saving data }}

在B頁面

loadOrderData = async () => { const __orderData = await AsyncStorage.getItem('Order_data_cache'); const orderData = JSON.parse(__orderData); this.setState({ orderData });}

缺點: 以 Key-Value 式的存儲傳參,可能重點還是在數據存儲上, 且因為涉及到 I/O 的操作,在部份低端機型上,有卡頓的可能性

React Context Api 傳參(新版Context Api)

推薦指數: ♥ ♥ ♥ 

適用范圍: 不同頁面間的組件共享公共類的數據

兼容性: IOS/Android

原理: 利用生成的數據倉庫包裹父級組件, 再從子組件中獲取數據倉庫中的數據 

說明: Context Api 在管理登錄用戶數據這類具有公共屬性的數據是一把利器, 但使用起來會相當繁瑣

 const ContextWrapper = React.createContext(); <ContextWrapper.Provider value={{ name: 'Mega Galaxy', job: 'FrontEnd Engineer' }} <App /> <ContextWrapper.Provider> // 注意這里的 <App /> 是指我們 App的根組件,在包裹根組件后 我們可以在任意子頁面組件 中取值

任意 <App /> 里的子頁面組件中

 <ContextWrapper.Counsumer>  { context => <Text> { context.name } { context.job }</Text> } </ContextWrapper.Counsumer> 會渲染成 <Text> Mega Galaxy FrontEnd Engineer </Text>

缺點: 理解需要花一些功夫, 寫法繁瑣,且只適合特定類型的數據,要明確組件間的包裹關系

Global 傳值

推薦指數: ♥ ♥ ♥ 

適用范圍: 頁面間傳值

兼容性: IOS/Android

原理: 利用 Node.js 中的頂級對象 Global 來掛載屬性, 利用屬性傳值

說明: 在跳轉的頁面前,可以把需要傳遞的參數掛載在 Global 對象上, 在跳轉后即可在 Global 對象上取過相同的鍵取到對應的值, 例如: 在 A 頁面跳轉 B 頁面時, Global.params = { name: 'Jalon', id: '123456'}, 在跳轉之后, 即可通過 Global.params 拿到值, 除了普通的字值串,布爾值,對象,數組, 也可以傳遞函數, 但要注意帶有 this.setState 方法的函數傳遞后 調用可能會報錯. 

缺點: 如果掛載的屬性/方法過多 易造成沖突與污染, 不利于維護

個人建議: 在 react-navigation 跳轉傳值 與 DeviceEventEmitter 維護不方便的情況下才使用, 但盡量少用, 以免造成 Global 屬性的污染與沖突

總結了5種常見的參數/數據傳遞的方法,以個人角度來看, 推薦順序為 React Navigation 導航傳值 > DeviceEventEmitter 觸發事件并傳值 > AsyncStorage Key-Value 式的存儲傳參, 最后 兩種是在特殊場景下才會去使用,所以朋友們,在合適的場景選擇合適的方式去傳值,會為React Native項目的開發帶來更為理想的效果,感謝您的閱讀,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 黔西县| 岱山县| 永康市| 西昌市| 江孜县| 揭东县| 桃江县| 休宁县| 上高县| 保德县| 蒙自县| 华蓥市| 上蔡县| 健康| 武威市| 忻城县| 盘锦市| 酒泉市| 和顺县| 炎陵县| 黑水县| 运城市| 甘洛县| 尼勒克县| 贵州省| 德惠市| 绥化市| 芜湖县| 加查县| 云南省| 兴仁县| 安阳市| 瓦房店市| 久治县| 济宁市| 泾阳县| 深州市| 苏尼特右旗| 宜阳县| 景东| 唐海县|