react-native - 如何在nativebase中的所有屏幕上使用通用页脚

标签 react-native native-base

我是react-native新手,我正在使用nativebase UI和React Navigation 我将这个屏幕作为主屏幕。

我正在使用原生基础组件容器页眉页脚

我的问题是如何创建一个可以在所有屏幕中导入的页脚或页眉文件?

所以我有一个通用的页脚模板,因为它在所有页面上都是相同的。

代码:

export default class Home extends React.Component {

  render() {
    return (
      <Container>
        <Header>
          <Left/>
          <Body>
            <Title>Home</Title>
          </Body>
          <Right />
        </Header>
        <Content>
          <Text>We have { this.props.screenProps.currentFriends.length } friends!</Text>
          <Button
            block
            onPress={() =>
              this.props.navigation.navigate('Friends')
            }
          >
          <Text>Add some friends</Text>
          </Button>
        </Content>

        <Footer>
          <FooterTab>
            <Button vertical active>
              <Icon name="apps" />
              <Text>Home</Text>
            </Button>
            <Button vertical>
              <Icon name="person" />
              <Text>Friends</Text>
            </Button>
          </FooterTab>
        </Footer>

      </Container>
    );
  }

}

最佳答案

可以有两种类型的可重用组件

  1. 有状态 - 可重用组件(页脚/页眉等)将拥有自己的状态
export default class MyFooter extends React.Component{

  render() {
    return (
      <Left>
        <Icon name="person" type="EvilIcon" />
        <Text>{props.name}</Text>
      </Left>
     );
   }
}
import MyFooter from "./MyFooter";  // <-- Don't forget to import

export default class YourScreen extends React.Component {

 constructor(props) {
    super(props);
  }

  render() {
    return (
       <Container>
        <Header/>
        <Content />
        <MyFooter name="Click Me" /> // <--- this is custom component
     );
   }
}
  • 无状态 - 它不会有任何状态,只需将这两个组件驻留在同一个文件 YourScreen.js
  • const MyFooter = props => {
      if (props.name) {
        return (
          <Left>
            <Icon name="person" type="EvilIcon" />
            <Text>{props.name}</Text>
          </Left>
        );
      } else {
        return null;
      }
    };
    
    export default class YourScreen extends React.Component {
    
      render() {
        return (
           <Container>
            <Header/>
            <Content />
            <MyFooter name="Click Me" /> // <--- this is custom component
         );
       }
    }
    

    关于react-native - 如何在nativebase中的所有屏幕上使用通用页脚,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55059348/

    相关文章:

    ios - React-Native NavigatorIOS 错误不适用于背景图像

    javascript - ReactNative Flatlist - RenderItem 不工作

    reactjs - 我们可以将 kafka 与 React Native 集成吗

    react-native - 如何通过ref访问react-native listview子组件?

    javascript - 将数组对象渲染到 FlatList React Native 中

    css - 在原生卡中启用溢出

    javascript - react native : state is getting undefined inside useCallBack hook function

    javascript - 强制 RTL 的 NativeBase 选项卡问题 - 修复

    react-native - 如何更改 native 基础的主题?

    javascript - React-Native:Native-base:失败的 Prop 类型:提供给 "NativeBase"的 props.style key "View"无效