2015-04-04 7 views
1

в ответном нативном документе Я не могу найти способ изменить нижние слова?Как я могу изменить слово в TabBarIOS в ответном нативном?

<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?

ответ

3

TabBarItem позволяет использовать один из предустановленных значков iOS от UITabBarSystemItem, а в вашем примере кода используется значок «Больше». Тем не менее, в документации для UITabBarSystemItem указано:

Невозможно изменить заголовок и изображение элементов панели инструментов системы.

Если установить иконку либо данные УИДР или локальное изображение, а не значок из UITabBarSystemItem, вы будете иметь возможность переопределить текст по этому пункту, что вы хотите, используя title опоры.

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); 
Смежные вопросы