Open In App

React Suite Affix Props

Improve
Improve
Like Article
Like
Save
Share
Report

React Suite is a popular front-end library with a set of React components that are designed for the middle platform and back-end products. 

Affix component allows the user to wrap Affix around another component in order to make it stick to the viewport. Affix is generally used for pages with long content.

The available properties of Affix are:

  • children:  It is used to denote the content of the component.
  • classPrefix: It is used to denote the prefix of the component CSS class.
  • container: It specifies the container.
  • onChange: This is a callback function that when triggered when the non-fixed and fixed state changes.
  • top: It sets the fixed-top height of the affix. It is specified using a number. By default, it is zero.

Approach: Let us create a React project and install React Suite module. Then we will create a UI that will showcase React Suite Affix Props.

Creating React Project:

Step 1: To create a react app, you need to install react modules through npx command. “npx” is used instead of “npm” because you will be needing this command in your app’s lifecycle only once.

npx create-react-app project_name

Step 2: After creating your react project, move into the folder to perform different operations.

cd project_name

Step 3: After creating the ReactJS application, Install the required module using the following command:

npm install rsuite

Project Structure: After running the commands mentioned in the above steps, if you open the project in an editor you can see a similar project structure as shown below. The new component user makes or the code changes, we will be performing will be done in the source folder.

Project Structure

Example 1: We are creating a UI that shows different React Suite Affix props.

App.js




import React from 'react'
import '../node_modules/rsuite/dist/rsuite.min.css';
import { Affix, Button } from 'rsuite';
import { Paragraph } from "@rsuite/icons";
  
export default function App() {
    return (
        <div style={{ margin: 100 }}>
            <h1 style={{ color: 'green' }}>GeeksforGeeks</h1>
            <h1>React Suite Affix Props</h1> <br></br>
            <Affix>
                <Button appearance="primary">
                    It will stay on top after the scroll .
                </Button>
            </Affix>
            <br /><br />
            <Paragraph style={{ fontSize: 1000 }} 
                rows={25} />
            <Paragraph style={{ fontSize: 1000 }} 
                rows={25} />
        </div>
    );
}


Step to Run Application: Run the application using the following command from the root directory of the project:

npm start

Output: Now open your browser and go to http://localhost:3000/, you will see the following output:

React Suite Affix

Example 2: We are creating a UI that shows different React Suite Affix props.

App.js




import React from 'react'
import '../node_modules/rsuite/dist/rsuite.min.css';
import { Affix, Button } from 'rsuite';
import { Paragraph } from "@rsuite/icons";
  
export default function App() {
    return (
        <div style={{ margin: 100 }}>
            <h1 style={{ color: 'green' }}>GeeksforGeeks</h1>
            <h1>React Suite Affix Props</h1> <br></br>
            <Affix top={50}>
                <Button color="green" appearance="primary" >
                    Content of the Affix 1. Top Prop set to 50.
                </Button>
            </Affix>
            <br /><br />
            <Affix top={150}>
                <Button color="yellow" appearance="primary" >
                    Content of the Affix 2. Top Prop set to 150.
                </Button>
            </Affix>
            <br /><br />
            <Paragraph style={{ fontSize: 1000 }} rows={25} />
            <Paragraph style={{ fontSize: 1000 }} rows={25} />
        </div>
    );
}


Output: Now open your browser and go to http://localhost:3000/, you will see the following output:

React Suite Affix with top prop

Reference: https://rsuitejs.com/components/affix/#code-lt-affix-gt-code



Last Updated : 28 Jun, 2022
Like Article
Save Article
Previous
Next
Share your thoughts in the comments
Similar Reads