日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

React Native封装Toast与加载Loading组件

發布時間:2025/4/16 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 React Native封装Toast与加载Loading组件 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

React Native開發封裝Toast與加載Loading組件

在App開發中,我們避免不了使用的兩個組件,一個Toast,一個網絡加載Loading,在RN開發中,也是一樣,React Native官方并沒有提供者這兩個常用組件,需要開發者自己根據需求來自定義。作者就在其他組件的基礎上在進行二次封裝,使用起來更加簡單,更具擴展性,同學們只需將Toast與Loading文件拖到項目中,install對應的組件庫即可

效果圖


gif

Toast和Loading Demo地址

https://github.com/guangqiang-liu/react-native-toastAndLoading

Demo使用使用到的三方組件

  • react-native-root-toast:用來顯示toast
  • react-native-root-siblings:用來Loading在App最上層添加視圖
  • react-native-vector-icons:IconFont

注意

react-native-vector-icons?需要link 才能使用,同學們需要注意

Toast組件

toast組件這里作者分類8種不同的使用場景,目前能想到的就這多場景了,后面同學們有其他場景,可以自行添加即可,Toast組件中使用到的Icon圖標,同學們也可以自行修改

  • 只顯示最簡單的文本的toast
  • 只顯示最簡單的文本的長toast,顯示時長 + 500毫秒
  • 顯示success的toast,success的Toast帶有一個成功的對號icon
  • 顯示success的toast,支持回調,使用場景類似于登錄成功,顯示1500毫秒toast,然后在回調函數中跳轉到其他頁面
  • 顯示success的長toast,顯示時長 + 500毫秒
  • 顯示success的長toast,顯示時長 + 500毫秒,支持回調,使用場景類似于登錄成功,顯示1000毫秒toast,然后跳轉到其他頁面
  • 顯示warning的toast,使用場景類似于登錄表單,手機號填寫錯誤
  • 顯示報錯的toast,使用場景類似于登錄表單,提交表單失敗

Loading組件

Loading組件最常用的使用場景就是網絡請求時,數據還沒有請求回來之前,頁面最上層顯示一個正在加載的loading框,一來能夠防止用戶在網絡請求時又做其他的操作,二來可以給用戶一個更好的體驗,不至于頁面空白,顯得突兀

  • loading支持手動調用顯示:show()
  • 支持手動關閉顯示:hidden()

這里作者建議使用redux來控制Loading的顯示與隱藏,這樣不用在每一個需要網絡請求的頁面都手動去調用顯示與隱藏,更高端的Loading使用技巧可以參照作者的React Native開發項目:OneM

Toast核心源碼

const Toast = {toast: null,show: msg => {this.toast = RootToast.show(msg, {position: 0,duration: 1500})},showLong: msg => {this.toast = RootToast.show(msg, {position: 0,duration: 2000})},showSuccess: (msg, options) => {let toast = RootToast.show(Platform.OS === 'ios' ?<View style={styles.container}><Icon name='check' size={50} color={'#fff'}/> <Text style={styles.message}>{msg}</Text> </View> : msg, { duration: 1500, position: RootToast.positions.CENTER, ...options, }) setTimeout(function () { RootToast.hide(toast) typeof options === 'function' ? options && options(): null }, 2000) }, showLongSuccess: (msg, options) => { let toast = RootToast.show( Platform.OS === 'ios' ? <View style={styles.container}> <Icon name='check' size={50} color={'#fff'}/> <Text style={styles.message}>{msg}</Text> </View> : msg, { duration: 2000, position: RootToast.positions.CENTER, ...options, }) setTimeout(function () { RootToast.hide(toast) typeof options === 'function' ? options && options(): null }, 2500) }, showWarning: (msg, options) => { let toast = RootToast.show( Platform.OS === 'ios' ? <View style={styles.container}> <Icon name='warning' size={40} color={'#fff'}/> <Text style={styles.message}>{msg}</Text> </View> : msg, { duration: RootToast.durations.SHORT, position: RootToast.positions.CENTER, ...options, }) setTimeout(function () { RootToast.hide(toast) }, RootToast.durations.SHORT + 500) }, showError: (msg, options) => { let toast = RootToast.show( Platform.OS === 'ios' ? <View style={styles.container}> <Icon name='close' size={40} color={'#fff'}/> <Text style={styles.message}>{msg}</Text> </View> : msg, { duration: RootToast.durations.SHORT, position: RootToast.positions.CENTER, ...options, }) setTimeout(function () { RootToast.hide(toast) }, RootToast.durations.SHORT + 500) } }

Loading核心源碼

const HUD = {show: () => {sibling = new RootSiblings( <View style={styles.maskStyle}> <View style={styles.backViewStyle}> <ActivityIndicator size="large" color="white" /> </View> </View> ) }, hidden: ()=> { if (sibling instanceof RootSiblings) { sibling.destroy() } } }

更多文章

  • 作者React Native開源項目OneM【500+ star】地址(按照企業開發標準搭建框架完成開發的):https://github.com/guangqiang-liu/OneM:歡迎小伙伴們?star
  • 作者簡書主頁:包含60多篇RN開發相關的技術文章http://www.jianshu.com/u/023338566ca5歡迎小伙伴們:多多關注,多多點贊
  • 作者React Native QQ技術交流群:620792950?歡迎小伙伴進群交流學習
  • 友情提示:在開發中有遇到RN相關的技術問題,歡迎小伙伴加入交流群(620792950),在群里提問、互相交流學習。交流群也定期更新最新的RN學習資料給大家,謝謝大家支持!

小伙伴們掃下方二維碼加入RN技術交流QQ群


QQ群二維碼,500+ RN工程師在等你加入哦

轉載于:https://www.cnblogs.com/guangqiang/p/9602093.html

總結

以上是生活随笔為你收集整理的React Native封装Toast与加载Loading组件的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。