How to add footer navigation with react native using native base library?

笑着哭i 提交于 2019-12-13 21:00:25

问题


am new for react native development am trying implement native base footer navigation but i couldn't make it work. Now let me explain what i have tried so far.

This is the class i have implemented footer navigation:

import React, { Component } from 'react';
// import { FlatList,
//    ActivityIndicator,
//    StyleSheet,
//     View,
//     TouchableNativeFeedback,
//     TouchableHighlight,
//    Text,
//    ListView,
//    Button
//   } from 'react-native';
import { AppRegistry, StyleSheet, ActivityIndicator, ListView, View, Alert,Image,Drawer , Title,Platform} from 'react-native';
import { Container, Header, Content, Footer, FooterTab, Button, Text } from 'native-base';
import First from './First';
import Sec from './Sec';
//import { Container, Header, Content, Badge, Text, Drawer,Icon } from 'native-base';
  import { firebases } from './config/firebase';
  import {Sidebar} from './slidebar';
  import {AppHeader} from './AppHeader';
//import { Card, CardTitle, CardContent, CardAction, CardButton, CardImage } from 'react-native-material-cards';

const instructions = Platform.select({
  ios: 'Press Cmd+R to reload,\n' +
    'Cmd+D or shake for dev menu',
  android: 'Double tap R on your keyboard to reload,\n' +
    'Shake or press menu button for dev menu',
});
const db=firebases.firestore();

const collection = db.collection('Users');
var ds = new ListView.DataSource({ rowHasChanged: (row1, row2) => row1 !== row2 })
export default class Second extends React.Component {

  constructor(props) {
    super(props);
   this.state = {
     isLoading: true,
     index: 0
   }


 }
 switchScreen(index) {
  this.setState({index: index})
}
GetItem (flower_name) {

 Alert.alert(flower_name);

 }


 componentDidMount() {
  var array=[];
  db
  .collection('Users')
  .get()
  .then(snapshot => {
    snapshot
      .docs
      .forEach(doc => {
        array.push({'Email':doc.data().Email,'Password':doc.data().Password});
      });
         alert(array[0]);
          let ds = new ListView.DataSource({rowHasChanged: (r1, r2) => r1 !== r2});
       this.setState({
         isLoading: false,
         dataSource: ds.cloneWithRows(array),
       }, function() {
         // In this block you can do something with new state.
       });
     })
     .catch((error) => {
       console.error(error);
     });




}

 ListViewItemSeparator = () => {
   return (
     <View
       style={{
         height: .5,
         width: "100%",
         backgroundColor: "#000",
       }}
     />
   );
 }


 render() {
  let AppComponent = null;

  if (this.state.index == 0) {
     AppComponent = First
  } else {
     AppComponent = Sec
  }



return (
  <Container>
  <Header><Title> Header... </Title></Header>
  <Content> <AppComponent/> </Content>
  <Footer>
      <Button onPress={() => this.switchScreen(0) }> First </Button>
      <Button onPress={() => this.switchScreen(1) }> Sec </Button>
  </Footer>
</Container>

  );
}}
const styles = StyleSheet.create({

MainContainer :{

// Setting up View inside content in Vertically center.
justifyContent: 'center',
flex:1,
margin: 5,
paddingTop: (Platform.OS === 'ios') ? 20 : 0,

},

imageViewContainer: {
width: '50%',
height: 100 ,
margin: 10,
borderRadius : 10

},

textViewContainer: {

  textAlignVertical:'center',
  width:'50%', 
  padding:20

}

});

This the class First:

import React, { Component } from "react";
import { Container, Header, Content, Card, CardItem, Text, Body } from "native-base";
export default class First extends Component {
  render() {
    return (
      <Container>
        <Header />
        <Content>
          <Card>
            <CardItem header button onPress={() => alert("This is Card Header")}>
              <Text>NativeBase</Text>
            </CardItem>
            <CardItem button onPress={() => alert("This is Card Body")}>
              <Body>
                <Text>
                  Click on any carditem
                </Text>
              </Body>
            </CardItem>
            <CardItem footer button onPress={() => alert("This is Card Footer")}>
              <Text>GeekyAnts</Text>
            </CardItem>
          </Card>
        </Content>
      </Container>
    );
  }
}module.exports = First

This is the class sec:

import React, { Component } from 'react';
import { Container, Header, Content, Button, Text } from 'native-base';
export default class Sec extends Component {
  render() {
    return (
      <Container>
        <Header />
        <Content>
          <Button bordered light>
            <Text>Light</Text>
          </Button>
          <Button bordered>
            <Text>Primary</Text>
          </Button>
          <Button bordered success>
            <Text>Success</Text>
          </Button>
          <Button bordered info>
            <Text>Info</Text>
          </Button>
          <Button bordered warning>
            <Text>Warning</Text>
          </Button>
          <Button bordered danger>
            <Text>Danger</Text>
          </Button>
          <Button bordered dark>
            <Text>Dark</Text>
          </Button>
        </Content>
      </Container>
    );
  }
}module.exports = Sec

Error am getting is: cannot add a child that doesn't have a yoganode parent without a measure function(try to add a react raw text shadownode to layout shadownode)

How to resolve this am i making any mistake please share any solution for this. Thanks in advance.

来源:https://stackoverflow.com/questions/53774572/how-to-add-footer-navigation-with-react-native-using-native-base-library

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!