Modals help show important messages or content on top of the page. Changing their size and position makes them fit better for different needs.
Modal sizes and positioning in Bootsrap
<div class="modal-dialog modal-sm"> <div class="modal-content"> <!-- Modal content here --> </div> </div>
Use modal-sm, modal-lg, or modal-xl classes on modal-dialog to change size.
By default, modals are centered horizontally. You can add modal-dialog-centered to center vertically.
<div class="modal-dialog modal-sm"> <div class="modal-content"> <!-- Small modal content --> </div> </div>
<div class="modal-dialog modal-lg modal-dialog-centered"> <div class="modal-content"> <!-- Large centered modal content --> </div> </div>
<div class="modal-dialog modal-xl"> <div class="modal-content"> <!-- Extra large modal content --> </div> </div>
This example shows three buttons that open modals of different sizes and positions. The small modal is compact, the large modal is centered vertically, and the extra large modal is very wide. All modals have accessible labels and close buttons.
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <title>Bootstrap Modal Sizes and Positioning</title> <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet" /> </head> <body> <div class="container py-4"> <h1>Modal Sizes and Positioning Demo</h1> <button type="button" class="btn btn-primary me-2" data-bs-toggle="modal" data-bs-target="#smallModal"> Small Modal </button> <button type="button" class="btn btn-success me-2" data-bs-toggle="modal" data-bs-target="#largeCenteredModal"> Large Centered Modal </button> <button type="button" class="btn btn-warning" data-bs-toggle="modal" data-bs-target="#extraLargeModal"> Extra Large Modal </button> </div> <!-- Small Modal --> <div class="modal fade" id="smallModal" tabindex="-1" aria-labelledby="smallModalLabel" aria-hidden="true"> <div class="modal-dialog modal-sm"> <div class="modal-content"> <div class="modal-header"> <h5 class="modal-title" id="smallModalLabel">Small Modal</h5> <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button> </div> <div class="modal-body"> This is a small modal for quick messages. </div> <div class="modal-footer"> <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button> </div> </div> </div> </div> <!-- Large Centered Modal --> <div class="modal fade" id="largeCenteredModal" tabindex="-1" aria-labelledby="largeCenteredModalLabel" aria-hidden="true"> <div class="modal-dialog modal-lg modal-dialog-centered"> <div class="modal-content"> <div class="modal-header"> <h5 class="modal-title" id="largeCenteredModalLabel">Large Centered Modal</h5> <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button> </div> <div class="modal-body"> This modal is large and vertically centered on the screen. </div> <div class="modal-footer"> <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button> </div> </div> </div> </div> <!-- Extra Large Modal --> <div class="modal fade" id="extraLargeModal" tabindex="-1" aria-labelledby="extraLargeModalLabel" aria-hidden="true"> <div class="modal-dialog modal-xl"> <div class="modal-content"> <div class="modal-header"> <h5 class="modal-title" id="extraLargeModalLabel">Extra Large Modal</h5> <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button> </div> <div class="modal-body"> This modal is extra large, perfect for showing a lot of content. </div> <div class="modal-footer"> <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button> </div> </div> </div> </div> <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script> </body> </html>
Always add aria-labelledby and aria-hidden for accessibility.
Use modal-dialog-centered to center modals vertically.
Test modals on different screen sizes to ensure they look good everywhere.
Use modal-sm, modal-lg, and modal-xl classes to control modal size.
Add modal-dialog-centered to center modals vertically on the screen.
Always include accessible labels and test responsiveness for best user experience.