Button

Button is a pure NativeBase component. Buttons are the integral part of an application. They are used for various purposes like, submit or reset a form, navigate, performing interactive actions such as showing or hiding something in an app on click of the button, etc.

Contents:

  • Button Theme
  • Block Button
  • Rounded Button
  • Icon Button
  • Outline Button
  • Transparent Button
  • Button Size
  • Disabled Button

Syntax

import React, { Component } from 'react';
import { Container, Content, Button, Header, Title } from 'native-base';

export default class ButtonExample1 extends Component {
  render() {
    return (
      <Container>
                <Header>
                    <Title>Button</Title>
                </Header>
        <Content>
          <Button> Click Me! </Button>
        </Content>
      </Container>
    );
  }
}
  • NativeBase provides Button component which is readily not available in React Native.
  • Supports React Native app on both iOS and Android devices.
  • Button component takes input such as: Text, Icon, Text with Icon.
  • NativeBase gives you privilege to customize the props of this component. Example: To have custom style for button, include them in style prop of button.
  • Intakes user-defined styles.
  • NativeBase has provided its users with enormous list of props that can be used with Button.
  • Replacing Component: React Native <TouchableOpacity>

Configuration

Property Default Option Description
style - - Defines button style
textStyle - - Defines button text style
block - - Block level button
rounded - - Renders button with slightly round shaped edges.
bordered - - Applies outline button style.
transparent - - Gives you effect of Icon-buttons.To have button with transparent background, include this prop.
small - - For small size button
large - - For large size button
iconLeft - - Used for Icon alignment.Aligns icon to the left in button.By default, icons are aligned to the left in button.
iconRight - - Used for Icon alignment.Aligns icon to the right in button.
disabled false true false Disables click option for button

Button Theme

NativeBase provides buttons with wide range of colors, size and variuos other props. NativeBase provides following color themes:

  • Primary (default)
  • Success
  • Info
  • Warning
  • Danger

Syntax

import React, { Component } from 'react';
import { Container, Content, Button, Header, Title } from 'native-base';

export default class ButtonExample2 extends Component {
  render() {
    return (
      <Container>
                <Header>
                    <Title>Button</Title>
                </Header>
        <Content>
          <Button primary> Primary </Button>
          <Button success> Success </Button>
          <Button info> Info </Button>
          <Button warning> Warning </Button>
          <Button danger> Danger </Button>
        </Content>
      </Container>
    );
  }
}

Block Button

A block level button spans the entire width of the parent element. Create block level buttons by adding block prop with the Button.

Syntax

import React, { Component } from 'react';
import { Container, Content, Button, Header, Title } from 'native-base';

export default class ButtonExample3 extends Component {
  render() {
    return (
      <Container>
                <Header>
                    <Title>Button</Title>
                </Header>
        <Content>
          <Button block> Primary </Button>
          <Button block success> Success </Button>
          <Button block info> Info </Button>
          <Button block warning> Warning </Button>
          <Button block danger> Danger </Button>
        </Content>
      </Container>
    );
  }
}

Rounded Button

Include rounded prop with Button to easily style your buttons.

Syntax

import React, { Component } from 'react';
import { Container, Content, Button } from 'native-base';

export default class RoundedButtonExample extends Component {
  render() {
    return (
      <Container>
        <Content>
          <Button rounded> Primary </Button>
          <Button rounded success> Success </Button>
          <Button rounded info> Info </Button>
          <Button rounded warning> Warning </Button>
          <Button rounded danger> Danger </Button>
        </Content>
      </Container>
    );
  }
}

Icon Button

The Icon Buttons, can take text and/or icon as child elements inside the Button. This goes as simple as this: include your choice of icon using Icon component within the Button component.

Syntax

import React, { Component } from 'react';
import { Container, Content, Button, Icon } from 'native-base';
​
export default class IconButtonExample extends Component {
  render() {
    return (
      <Container>
        <Content>
          <Button primary>
            <Icon name='ios-home' />
            Home
          </Button>

          <Button success iconRight>
            Next
            <Icon name='ios-arrow-forward' />
          </Button>

          <Button info>
            Previous
            <Icon name='ios-arrow-back' />
          </Button>

          <Button warning>
            <Icon name='ios-star' />
          </Button>

          <Button danger>
            <Icon name='ios-close' />
          </Button>

          <Button style={{backgroundColor: '#384850'}} >
            <Icon name='ios-search' style={{color: '#00c497'}}/>
          </Button>
        </Content>
      </Container>
    );
  }
}

Outline Button

Include bordered prop with Button to apply outline button style.

Syntax

import React, { Component } from 'react';
import { Container, Content, Button } from 'native-base';

export default class OutlineButtonExample extends Component {
  render() {
    return (
      <Container>
        <Content>
          <Button bordered> Primary </Button>
          <Button bordered success> Success </Button>
          <Button bordered info> Info </Button>
          <Button bordered warning> Warning </Button>
          <Button bordered danger> Danger </Button>
        </Content>
      </Container>
    );
  }
}

Transparent Button

Include transparent prop with Button. This will render button without border and background color.

Syntax

import React, { Component } from 'react';
import { Container, Content, Button } from 'native-base';

export default class TransparentButtonExample extends Component {
  render() {
    return (
      <Container>
        <Content>
          <Button transparent> Primary </Button>
          <Button transparent>
            <Icon name='ios-home' style={{fontSize: 20, color: '#00c497'}} />
          </Button>
        </Content>
      </Container>
    );
  }
}

results matching ""

    No results matching ""