解决React Native中使用TabNavigator时、对tab只设置文字时文字没有垂直居中

前端之家收集整理的这篇文章主要介绍了解决React Native中使用TabNavigator时、对tab只设置文字时文字没有垂直居中前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

使用react-navigation中的TabNavigator搭建标签导航栏的时候遇到了一个问题,

当我们对导航栏只需要设置文字,不设置图片的时候、在ios设备上你会发现文字没有垂直居中(在Android中是好的),

因为这个控件默认预留好了图片显示的位置 即使你将showIcon: false设置为false还是一样没有用,我们来看下效果图对比:

同时设置图片文字是正常的

当只设置文字

只需要设置文字时,文字一直在Tab的底部….

纠结了好几天在网上一直找不到答案非常的郁闷…. 幸好功夫不负有心人终于找了答案,看下垂直居中的效果图:

解决方案:单独给ios端设置一个tabStyle:{height:35},这样就不会影响到Android端了

原文链接http://www.cnblogs.com/moxiaoyan33/p/5710991.html

1.创建一个StyleSheet.js文件

  1. /**
  2. *根据ios android 设备设置不同的style
  3. */
  4.  
  5. import {StyleSheet,Platform} from 'react-native';
  6.  
  7. export function create(styles: Object): { [name: string]: number } {
  8. const platformStyles = {};
  9. Object.keys(styles).forEach((name) => { let {ios,android,...style} = {...styles[name]}; if (ios && Platform.OS === 'ios') { style = {...style,...ios}; } if (android && Platform.OS === 'android') { style = {...style,...android}; } platformStyles[name] = style; }); return StyleSheet.create(platformStyles); }

2.在配置Tab的地方引用这个文件,设置样式。

  1. const StyleSheet = require('../../../src/common/StyleSheet');
  2.  
  3. const styles = StyleSheet.create({
  4. tabStyle: {
  5. ios: {
  6. height: 35,},android: {},}
  7. });
  8. export default Tab = TabNavigator({
  9.  
  10. Joke: {
  11. screen: Joke,navigationOptions: {
  12. tabBarLabel: '笑话',riddles: {
  13. screen: Riddles,navigationOptions: {
  14. tabBarLabel: '谜语',}
  15. }
  16.  
  17. },{
  18. //设置TabNavigator的位置
  19. tabBarPosition: 'top',//...
  20. tabBarOptions: {
  21. showIcon: false,//...
  22. tabStyle: styles.tabStyle,});

通过以上步骤就可以完美解决!

过程时心酸的,结果是美好的。

猜你在找的React相关文章