Description
See live demo here.
Extends Bootstrap's native modals to provide additional functionality. Introduces a ModalManager class that operates behind the scenes to handle multiple modals by listening on their events.
A single ModalManager is created by default on body and can be accessed through the jQuery plugin interface.
bootstrap-modal alternatives and similar libraries
Based on the "Modals and Popups" category.
Alternatively, view bootstrap-modal alternatives based on common mentions on social networks and blogs.
-
SweetAlert
A beautiful replacement for JavaScript's "alert" -
sweetalert2
✨ A beautiful, responsive, highly customizable and accessible (WAI-ARIA) replacement for JavaScript's popup boxes. Zero dependencies. 🇺🇦 -
Magnific-Popup
Light and responsive lightbox script with focus on performance. -
fancyBox
jQuery lightbox script for displaying images, videos and more. Touch enabled, responsive and fully customizable. -
X-editable
In-place editing with Twitter Bootstrap, jQuery UI or pure jQuery -
tether
A positioning engine to make overlays, tooltips and dropdowns better -
lightGallery
A customizable, modular, responsive, lightbox gallery plugin. -
screenfull.js
Simple wrapper for cross-browser usage of the JavaScript Fullscreen API -
vex
A modern dialog library which is highly configurable and easy to style. #hubspot-open-source -
colorbox
A light-weight, customizable lightbox plugin for jQuery -
Bootbox
Wrappers for JavaScript alert(), confirm() and other flexible dialogs using Twitter's bootstrap framework -
lightgallery.js
Full featured JavaScript image & video gallery. No dependencies -
baguetteBox.js
:zap: Simple and easy to use lightbox script written in pure JavaScript -
iziModal
Elegant, responsive, flexible and lightweight modal plugin with jQuery. -
jquery.avgrund.js
Avgrund is jQuery plugin with new modal concept for popups -
css-modal
A modal built with pure CSS, enhanced with JavaScript -
jBox
jBox is a jQuery plugin that makes it easy to create customizable tooltips, modal windows, image galleries and more. -
GLightbox
Pure Javascript lightbox with mobile support. It can handle images, videos with autoplay, inline content and iframes -
🦞 Modali
A delightful modal dialog component for React, built from the ground up to support React Hooks. -
hColumns
jQuery.hColumns is a jQuery plugin that looks like Mac OS X Finder's column view for the hierarchical data. -
F$D€
F$D€ - Client not paid? Add opacity to the body tag and increase it every day until their site completely fades away -
ModalSquared.js
ModalSquared.js is a super small less than a 1kb library for showing and hiding modals.
A Non-Cloud Alternative to Google Forms that has it all.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of bootstrap-modal or a related project?
README
Note: Since this plugin was created to solve a lot of the issues with BS2, it still uses the BS2 markup syntax. Currently I believe the default BS3 modal addresses some of the bigger issues and is not worth maintaining two versions of this plugin.
Bootstrap Modal v2.2.6
See live demo here.
Extends Bootstrap's native modals to provide additional functionality. Introduces a ModalManager class that operates behind the scenes to handle multiple modals by listening on their events.
A single ModalManager is created by default on body and can be accessed through the jQuery plugin interface.
$('body').modalmanager('loading');
Bootstrap-Modal can be used as a replacement for Bootstrap's Modal class or as a patch to the library.
Bootstrap 3
If you're using BS3, I've provided a compatible css patch. Include bootstrap-modal-bs3patch.css
before the main bootstrap-modal.css
file to use this plugin with Bootstrap 3.
If you're using the loading spinner functionality you may also need to change the default template to be compatible in js:
$.fn.modal.defaults.spinner = $.fn.modalmanager.defaults.spinner =
'<div class="loading-spinner" style="width: 200px; margin-left: -100px;">' +
'<div class="progress progress-striped active">' +
'<div class="progress-bar" style="width: 100%;"></div>' +
'</div>' +
'</div>';
Overview
- Backwards compatible
- Responsive
- Stackable
- Full width
- Load content via AJAX
- Disable background scrolling
Installation
- Include
css/bootstrap-modal.css
after the main bootstrap css files. Include
js/bootstrap-modalmanager.js
andjs/bootstrap-modal.js
after the main bootstrap js files.<link href="css/bootstrap.css" rel="stylesheet" /> <link href="css/bootstrap-responsive.css" rel="stylesheet" /> <link href="css/bootstrap-modal.css" rel="stylesheet" /> <script src="js/bootstrap.js"></script> <script src="js/bootstrap-modalmanager.js"></script> <script src="js/bootstrap-modal.js"></script>
Options
In addition to the standard bootstrap options, you now have access to the following options
Modal
width Set the initial width of the modal.
height Set the initial height of the modal.
maxHeight Set the max-height of the modal-body.
loading Toggle the loading state.
spinner Provide a custom image or animation for the loading spinner.
backdropTemplate Provide a custom modal backdrop.
consumeTab Used to enable tabindexing for modals with
data-tabindex
. This is set to true by default.focusOn The element or selector to set the focus to once the modal is shown.
replace If set to true, the modal will replace the topmost modal when opened.
attentionAnimation Set the animation used by the
attention
method. Any animation in animate.css is supported but only the shake animation is included by default.modalOverflow Set this property to true for modals with highly dynamic content. This will force the modal to behave as if it is larger than the viewport.
manager Set the modal's manager. By default this is set to the
GlobalModalManager
and will most likely not need to be overridden.
ModalManager
loading Toggle the loading state.
backdropLimit Limit the amount of backdrops that will appear on the page at the same time.
spinner Provide a custom image or animation for the loading spinner.
backdropTemplate Provide a custom modalmanager backdrop. This backdrop is used when
$element.modalmanager('loading')
is called.
Getting a reference to the modal manager
If you did not created your own ModalManager, perhaps you'll need a reference to it. That can be easily accomplished using the following snippet:
var modalManager = $("body").data("modalmanager");
var openModals = modalManager.getOpenModals();
modalManager.removeLoading();
After that, you'll be able to call any methods that modal manager has, such as:
- removeLoading (remove the loading and backdrop window);
- getOpenModals (to get the modals that are already open);
- etc;
Disable Background Scrolling
If you want to prevent the background page from scrolling (see demo for example) you must wrap the page contents in a <div class="page-container">
. For example:
<body>
<div class="page-container">
<div class="navbar navbar-fixed-top">...</div>
<div class="container">...</div>
</div>
</body>
The reason for doing this instead of just simply setting overflow: hidden
when a modal is open is to avoid having the page shift as a result of the scrollbar appearing/disappearing. This also allows the document to be scrollable when there is a tall modal but only to the height of the modal, not the entire page.
Constrain Modal to Window Size
You can bind the height of the modal body to the window with something like this:
$.fn.modal.defaults.maxHeight = function(){
// subtract the height of the modal header and footer
return $(window).height() - 165;
}
Note: This will be overwritten by the responsiveness and is only set when the modal is displayed, not when the window is resized.
Tab Index for Modal Forms
You can use data-tabindex
instead of the default tabindex
to specify the tabindex within a modal.
<input type="text" data-tabindex="1" />
<input type="text" data-tabindex="2" />
See the stackable example on the demo page for an example.