如何在React Native中更改TabBarIOS中的文本?

时间:2015-04-04 09:51:52

标签: react-native

在本机文档中,我找不到改变底层词的方法吗?

    <TabBarItemIOS
      name="greenTab"
      icon={_ix_DEPRECATED('more')}
      accessibilityLabel="Green Tab"
      selected={this.state.selectedTab === 'greenTab'}
      onPress={() => {
        this.setState({
          selectedTab: 'greenTab',
          presses: this.state.presses + 1
        });
      }}>
      {this._renderContent('#21551C', 'Green Tab')}
    </TabBarItemIOS>

什么是accessibilityLabel?

2 个答案:

答案 0 :(得分:3)

TabBarItem允许您使用UITabBarSystemItem中的一个iOS预设图标,并在您的示例代码中使用&#34;更多&#34;图标。但至关重要的是,UITabBarSystemItem的文档指出:

  

无法更改系统标签栏项目的标题和图像。

如果您将图标设置为data-uri或本地图像,而不是UITabBarSystemItem中的图标,则您可以使用{{1}将项目上的文本覆盖为您想要的任何内容道具

答案 1 :(得分:0)

您可以使用自定义图标

为TabBarIOS.Item尝试类似的操作
import React, { Component } from 'react'
import { AppRegistry, StyleSheet, Text, View, TouchableOpacity, TabBarIOS } from 'react-native'

const base64Icon = ''

class ReactNativePlayground extends Component {

    constructor(props) {
        super(props)

        this.state = {
            selectedTab: "more",
            tabBarItemTitle: "More"
        }
    }

    render() {
        return (
            <TabBarIOS>

                <TabBarIOS.Item selected={this.state.selectedTab === "more"}
                                title={this.state.tabBarItemTitle}
                                icon={{uri: base64Icon, scale: 3}}>
                    <View style={styles.container}>
                        <TouchableOpacity onPress={ (event) => { this._changeTabItemTitle() } }>
                            <Text style={styles.button}>Tap to Change Item Title</Text>
                        </TouchableOpacity>
                    </View>
                </TabBarIOS.Item>

            </TabBarIOS>
        );
    }

    _changeTabItemTitle() {
        this.setState({ tabBarItemTitle: "New More" })
    }
}

const styles = StyleSheet.create({
    container: {
        flex: 1,
        justifyContent: 'center',
    },
    button: {
        fontSize: 20,
        color: "white",
        textAlign: 'center',
        backgroundColor: "#1155DD",
        borderRadius: 5,
        height: 30,
        margin: 30,
    },
});

AppRegistry.registerComponent('ReactNativePlayground', () => ReactNativePlayground);