亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

React Navigation 使用中遇到的問題小結

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

React Native的開發中,使用到react navigation框架時遇到了不少問題。主要是安卓和iOS中相對不協調的地方,特此記錄

一、Navigation Bar

使用navigationbar的時候遇到如下的問題

1.navigation bar的底部有一條黑線

本意做一個bar的顏色和頁面顏色一致的頁面。只有頂部有兩個其他按鈕的時候。發現bar的底部有一條黑線。導致bar不能很好的匹配想要的頁面效果。在header中設置一下代碼中后可去除

static navigationOptions = { ... headerStyle: {    ...    borderBottomWidth: 0,  }, }

2. android 的 Bar底部有一條陰影,自定義Bar背景圖無法填充滿

react navigation bar在安卓中默認會有一個高度。帶來的視覺效果是底部會有一條陰影。而且造成另外一個比較頭疼的效果是如果使用了帶背景圖的自定義Bar時。會發現背景圖有覆蓋不全的效果。兩側總有一些間隙。iOS中則不會出現此問題。將elevation屬性置零后可解決這個問題

 static navigationOptions = { ... headerStyle: {    ...    elevation: 0,  }, }

3.android 中Bar標題居中問題

在安卓中,bar 的標題是居左的。iOS則默認居中??梢酝ㄟ^以下寫法居中

static navigationOptions = { ... headerTitleStyle: {    //此屬性是標題的Style屬性??梢越邮?lt;Text>標簽的style    ...    alignSelf: "center",  }, }

在左側沒有按鍵的時候。這樣寫就足夠了。但是如果左側有個返回鍵或者自定義的其他按鍵。在安卓中標題就會發生偏移。解決辦法是右側添加一個空按鈕

static navigationOptions = { ... headerRight: <View /> }

4.帶背景圖的Navgation Bar

與源生不同。react navigation bar中并沒有背景圖這一屬性。也就是說我們要使用帶背景圖的navigation bar的時候必須要使用自定義的view。

import {Header} from "react-navigation";//header 需導入const ImageHeader = props => (  <View>    <Image      style={{position: "absolute", zIndex: -1, width: "100%", height: "100%", resizeMode: "cover"}}      source={require(...)}    />    <Header {...props} style={{backgroundColor: "transparent"}} />  </View>);static navigationOptions = { ... headerStyle: {   //背景顏色必須為透明,不然無法透出底部圖片   backgroundColor: "transparent",   //安卓中不添加此屬性會導致背景圖無法鋪滿   elevation: 0, },  header: props => {    return <ImageHeader {...props} />;  }, }

5.當StackNavigator與DrawerNavigator嵌套使用時手勢沖突問題

當DrawerNavigator嵌套StackNavigator時。進入StackNav的二級界面后返回手勢與打開DrawerNav打開菜單沖突。

static navigationOptions = { ... //禁止打開菜單 drawerLockMode: "locked-closed",  //允許使用返回手勢 gesturesEnabled: true, }

此設置按照需求自行修改

5.Navgation Bar高度不一致問題

使用自定義的Bar時。安卓和iOS高度不一致。Android計算Nav高度是從手機頂部開始計算。而iOS默認會向下偏移狀態欄的高度。要做到效果統一。需要將安卓的Bar的paddingTop屬性設為狀態欄高度

import {StatusBar, Platform} from "react-native";navigationOptions = { ... headerStyle: {   ...   paddingTop: Platform.OS === "ios" ? 0 : StatusBar.currentHeight,  }, }

6.navigation Bar上使用自定義按鈕

使用headerRight 或者 headerLeft 可以定制按鈕或者View

static navigationOptions = { ... headerRight = (<TouchableOpacity style={{marginRight: 10}} onPress={...}>        <Text style={styles.NavSureButton}>btn</Text>      </TouchableOpacity>) }

但是如果onPress方法要用到this.props、this.state或者是類中的其他方法的時候就會出現問題

在每個頁面的類中,我們使用static navigationOptions={...}來配置navigation的一些配置。但是由于static 修飾的屬性屬于類的靜態屬性。無法調用this的屬性方法。所以我們需要使用this.props.navigation.setParams({key:value ...})方法來設置header按鈕的點擊事件。

class Demo extends React,Component{ componentWillMount() {  //綁定方法  this.props.navigation.setParams({rightOnPress: this.rightBtnOnPress}); } //點擊方法 rightBtnOnPress = ()=>{  ... }  static navigationOptions = ({navigation}) => {    const params = navigation.state.params || {};    let navigationOptions = {    ...    headerRight = (<TouchableOpacity style={{marginRight: 10}} onPress={params.rightOnPress}>        <Text style={styles.NavSureButton}>btn</Text>      </TouchableOpacity>)    }    return navigationOptions;  };  ...}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
人妖精品videosex性欧美| 欧美性猛交xxxx免费看久久久| 国产精品中文久久久久久久| 欧美黑人极品猛少妇色xxxxx| 亚洲国产精品久久精品怡红院| 久久精品夜夜夜夜夜久久| 欧美激情精品久久久久久久变态| 欧美成人手机在线| 色婷婷av一区二区三区在线观看| 欧美电影《睫毛膏》| 久久久久久久久久久国产| 91精品国产高清| 91精品久久久久久久久久| 国产亚洲美女精品久久久| 亚洲午夜女主播在线直播| 精品国产91乱高清在线观看| 亚洲视频电影图片偷拍一区| 韩国v欧美v日本v亚洲| 亚洲精品黄网在线观看| 欧美自拍视频在线观看| 亚洲自拍高清视频网站| 国产精品日韩电影| 一区二区三区久久精品| 国产在线精品自拍| 日韩在线视频二区| 91丝袜美腿美女视频网站| 欧美理论电影网| 成人在线视频网站| 欧美精品激情blacked18| 91精品国产自产在线观看永久| 久久久久久国产三级电影| 久久久久久久久久久av| 欧美裸体xxxx极品少妇| 91产国在线观看动作片喷水| 国产日韩欧美一二三区| 91国产美女在线观看| 国产精品 欧美在线| 久久久久久一区二区三区| 国产综合在线观看视频| 午夜美女久久久久爽久久| 成人欧美一区二区三区黑人孕妇| 亚洲天堂影视av| 久久大大胆人体| 清纯唯美亚洲综合| 日韩在线观看你懂的| 日韩欧美国产成人| 26uuu另类亚洲欧美日本老年| 久久精品99国产精品酒店日本| 欧美成人三级视频网站| 亚洲精品在线视频| 粗暴蹂躏中文一区二区三区| 欧美电影在线免费观看网站| 国产精品日日做人人爱| 亚洲精品国产欧美| 91九色国产视频| 欧美激情按摩在线| 欧美黑人巨大精品一区二区| 亚洲一区二区精品| www.欧美三级电影.com| 91网站免费看| 亚洲精品91美女久久久久久久| 亚洲日韩中文字幕| 91免费电影网站| 97成人在线视频| 在线播放国产一区二区三区| 亚洲男人天堂网| 亚洲日本中文字幕免费在线不卡| 欧美综合一区第一页| 亚洲电影免费观看高清完整版在线观看| 欧美日韩激情小视频| 青草青草久热精品视频在线观看| 日韩女在线观看| 国产视频久久久久久久| 日韩精品久久久久久福利| 中文字幕国产亚洲2019| 亚洲欧美成人在线| 红桃av永久久久| 琪琪亚洲精品午夜在线| 亚洲欧美激情在线视频| 欧美激情videoshd| 国产精品丝袜白浆摸在线| 久久色在线播放| 精品欧美激情精品一区| 久久久久久69| 久久久久久久久久婷婷| 国产精品福利片| 亚洲自拍偷拍色片视频| 久久亚洲成人精品| 亚洲激情自拍图| 亚洲国产另类久久精品| 国产精品视频区1| 2019中文字幕在线| 亚洲综合国产精品| 神马久久久久久| 九九热最新视频//这里只有精品| 亚洲欧美精品在线| 中文字幕精品在线| 欧美视频国产精品| 欧美激情精品在线| 久久久久久久久久久免费精品| 日韩在线视频线视频免费网站| 亚洲人成啪啪网站| 久久夜色精品国产| 疯狂做受xxxx高潮欧美日本| 亚洲偷熟乱区亚洲香蕉av| 国产精品视频网| 最近2019年中文视频免费在线观看| 不卡毛片在线看| 91av在线免费观看视频| 国自在线精品视频| 97色在线视频| 一区二区三区国产在线观看| 亚洲一区二区三区乱码aⅴ| 欧美电影电视剧在线观看| 欧美在线视频观看免费网站| 中文字幕日韩免费视频| 爽爽爽爽爽爽爽成人免费观看| 亚洲成色999久久网站| 高清一区二区三区日本久| 大伊人狠狠躁夜夜躁av一区| 亚洲国产精品小视频| 亚洲综合视频1区| 在线看日韩欧美| 九色成人免费视频| 国产成人精品在线播放| 一区二区亚洲欧洲国产日韩| 永久免费精品影视网站| 亚洲色无码播放| 美日韩在线视频| 成人乱色短篇合集| 亚洲国产欧美一区二区丝袜黑人| 国产日本欧美一区| 日韩在线观看免费高清| 97久久精品国产| 日韩一区二区欧美| 欧美成人激情图片网| 国语自产精品视频在线看一大j8| 91日本视频在线| 少妇久久久久久| 成人激情综合网| 91高清免费在线观看| 92国产精品久久久久首页| 97超级碰碰碰| 亚洲成人免费网站| 欧美日韩国产一区中文午夜| 日韩av在线资源| 精品亚洲永久免费精品| 国产精品成人免费电影| 尤物yw午夜国产精品视频明星| www.久久撸.com| 国产精品海角社区在线观看| 精品国模在线视频| 国产精品精品国产| 久久97精品久久久久久久不卡| 日韩欧美在线免费观看| 欧美日韩国产区| 国产欧美一区二区三区久久人妖| 欧美视频国产精品| 国产成人精品久久二区二区| 亚洲aⅴ日韩av电影在线观看| 亚洲成人久久久久| 久久久伊人日本| 久久久久久这里只有精品| 中文字幕成人在线|