第一个带tabbar的RN项目

来源:互联网 发布:托脉林阴囊托淘宝 编辑:程序博客网 时间:2024/06/04 15:26
/** * Sample React Native App * https://github.com/facebook/react-native * @flow */var React = require('react');var ReactNative = require('react-native');var {  StyleSheet,  AppRegistry,  TabBarIOS,  Text,  View,} = ReactNative;var base64Icon = '';var MTRN = React.createClass({  statics: {    title: '<TabBarIOS>',    description: 'Tab-based navigation.',  },  displayName: 'TabBarExample',  getInitialState: function() {    return {      selectedTab: 'redTab',      notifCount: 0,      presses: 0,    };  },   _renderContent: function(color: string, pageText: string, num?: number) {    return (      <View style={[styles.tabContent, {backgroundColor: color}]}>        <Text style={styles.tabText}>{pageText}</Text>        <Text style={styles.tabText}>{num} re-renders of the {pageText}</Text>      </View>    );  },  render: function() {    return (      <TabBarIOS        unselectedTintColor="yellow"        tintColor="white"        barTintColor="darkslateblue">        <TabBarIOS.Item          title="Blue Tab"          icon={{uri: base64Icon, scale: 3}}          selected={this.state.selectedTab === 'blueTab'}          onPress={() => {            this.setState({              selectedTab: 'blueTab',            });          }}>          {this._renderContent('#414A8C', 'Blue Tab')}        </TabBarIOS.Item>        <TabBarIOS.Item          systemIcon="history"          badge={this.state.notifCount > 0 ? this.state.notifCount : undefined}          selected={this.state.selectedTab === 'redTab'}          onPress={() => {            this.setState({              selectedTab: 'redTab',              notifCount: this.state.notifCount + 1,            });          }}>          {this._renderContent('#783E33', 'Red Tab', this.state.notifCount)}        </TabBarIOS.Item>        <TabBarIOS.Item          icon={require('./flux.png')}          selectedIcon={require('./relay.png')}          renderAsOriginal          title="More"          selected={this.state.selectedTab === 'greenTab'}          onPress={() => {            this.setState({              selectedTab: 'greenTab',              presses: this.state.presses + 1            });          }}>          {this._renderContent('#21551C', 'Green Tab', this.state.presses)}        </TabBarIOS.Item>      </TabBarIOS>    );  },});var styles = StyleSheet.create({  tabContent: {    flex: 1,    alignItems: 'center',  },  tabText: {    color: 'white',    margin: 50,  },});const styles = StyleSheet.create({  container: {    flex: 1,    justifyContent: 'center',    alignItems: 'center',    backgroundColor: '#F5FCFF',  },  welcome: {    fontSize: 20,    textAlign: 'center',    margin: 10,  },  instructions: {    textAlign: 'center',    color: '#333333',    marginBottom: 5,  },});AppRegistry.registerComponent('MTRN', () => MTRN);

属性:

barTintColor string -------------- 标签栏的背景颜色。
tintColor string       -------------- 当前被选中的标签图标的颜色。
translucent bool     -------------- 一个布尔值,决定标签栏是否需要半透明化。

导入官方文档TabbarIOS组件,在终端运行react-native runios

ps:(由于官方demo 少了flux.png。。。所以运行后会报错,可自行添加一样名字的图片解决)

0 0