yes , you can use bootstrap and react-bootstrap inside next.js.
and i am use it inside my applications ,
and here is a simple example to use navbar and modal component just for testing ..
1- first install "react-bootstrap bootstrap" by using the follwing commands :
npm install react-bootstrap bootstrap
2- inside "_app.js" file import bootstrap css file on the top of file , and bootstrap js file inside useEffect , like the following :
import { useEffect } from 'react';
import Nav from '../components/nav'
import 'bootstrap/dist/css/bootstrap.css';
function MyApp({ Component, pageProps }) {
useEffect(() => {
require ('bootstrap/dist/js/bootstrap.js')
}, []);
return (
<>
<Nav />
<Component {...pageProps} />
</>
)
}
3- and here is the my Nav component for testing (compatible with bootstrap 5) ... :
import { useState } from "react";
import {Modal, Button} from 'react-bootstrap';
const Nav = () => {
const [show, setShow] = useState(false);
const handleClose = () => setShow(false);
const handleShow = () => setShow(true);
const confirm_modal = () => {
console.log('modal is working ...')
setShow(false)
}
return(
<>
<nav className="navbar navbar-expand-lg navbar-light bg-light">
<div className="container-fluid">
<a className="navbar-brand" href="#">Navbar</a>
<button className="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
<span className="navbar-toggler-icon"></span>
</button>
<div className="collapse navbar-collapse" id="navbarSupportedContent">
<ul className="navbar-nav me-auto mb-2 mb-lg-0">
<li className="nav-item">
<a className="nav-link" onClick={handleShow} href="#"> test modal</a>
</li>
<li className="nav-item dropdown">
<a className="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-bs-toggle="dropdown" aria-expanded="false">
Dropdown
</a>
<ul className="dropdown-menu" aria-labelledby="navbarDropdown">
<li><a className="dropdown-item" href="#">Action</a></li>
<li><a className="dropdown-item" href="#">Another action</a></li>
<li><hr className="dropdown-divider" /></li>
<li><a className="dropdown-item" href="#">Something else here</a></li>
</ul>
</li>
</ul>
<form className="d-flex">
<input className="form-control me-2" type="search" placeholder="Search" aria-label="Search" />
<button className="btn btn-outline-success" type="submit">Search</button>
</form>
</div>
</div>
</nav>
<Modal show={show} onHide={handleClose} keyboard="false">
<Modal.Header closeButton>
<Modal.Title>Modal heading</Modal.Title>
</Modal.Header>
<Modal.Body>Are You Sure You Want This!.</Modal.Body>
<Modal.Footer>
<Button variant="secondary" onClick={handleClose}>
Close
</Button>
<Button variant="danger" onClick={ confirm_modal }>
Yes
</Button>
</Modal.Footer>
</Modal>
</>
)
}
export default Nav
4- now create any page (for example index.js) and test it .
how to test :
1- if you see bootstrap styles showing on navbar (colors , Buttons styles ) that's means the 'boostrap css is working fine'.
2- if the dropdown menue is clickable and working , that's means bootstrap js file is working fine .
3- if the test modal works and you see the confirmation box , that's means the react-bootstrap components works fine .
this is just example and change it based on your case/requirements .
i hope this helpful for you .
spanin dev tools, then yourreact-bootstrapis working fine. You just need to providevariant="primary"like<Badge variant="primary">Heading</Badge>. Read more about variant