What is magnific-popup?
Magnific Popup is a responsive lightbox & dialog script with focus on performance and providing best experience for user with any device.
What are magnific-popup's main functionalities?
Image Lightbox
This feature allows you to open images in a lightbox. The code sample demonstrates how to initialize a magnificPopup for elements with the class 'image-link' to display images in a popup.
$(document).ready(function() {
$('.image-link').magnificPopup({type:'image'});
});
Gallery Lightbox
This feature enables a gallery of images to be displayed in a lightbox with navigation controls. The code sample shows how to set up a gallery using magnificPopup by delegating 'a' elements within a '.gallery' container.
$(document).ready(function() {
$('.gallery').magnificPopup({
delegate: 'a',
type: 'image',
gallery: {enabled: true}
});
});
Inline Content
This feature allows you to display inline HTML content in a popup. The code sample demonstrates how to open inline content using magnificPopup for elements with the class 'inline-popup'.
$(document).ready(function() {
$('.inline-popup').magnificPopup({
type: 'inline',
midClick: true
});
});
Ajax Content
This feature allows you to load content via AJAX and display it in a popup. The code sample shows how to initialize magnificPopup for elements with the class 'ajax-popup' to load content asynchronously.
$(document).ready(function() {
$('.ajax-popup').magnificPopup({
type: 'ajax'
});
});
Other packages similar to magnific-popup
fancybox
Fancybox is a tool for displaying images, HTML content, and multi-media in a Mac-style 'lightbox' that floats overtop of web pages. It is similar to Magnific Popup in terms of functionality but offers more built-in themes and a more extensive API for customization.
lightgallery
Lightgallery is a modern, responsive, modular, and customizable image & video gallery plugin. It offers similar features to Magnific Popup, such as image and video lightboxes, but also includes additional features like thumbnail navigation and zoom functionality.
photoswipe
PhotoSwipe is a JavaScript image gallery for mobile and desktop, modular and framework-independent. It is similar to Magnific Popup in providing a responsive lightbox experience but is more focused on providing a mobile-friendly interface with touch gestures.
Important note This jQuery plugin is deprecated, only critical or security bug fixes will be released in future. Use native <dialog>
element if you need a basic dialog/modal/popup, or my PhotoSwipe library if you need an advanced image gallery. Feel free to email me if you need assistance.
Fast, light and responsive lightbox plugin, for jQuery and Zepto.js.
Optionally, install via Bower bower install magnific-popup
or npm: npm install magnific-popup
.
Ruby gem: gem install magnific-popup-rails
.
Extensions
If you created an extension for some CMS, email me and I'll add it to this list.
Location of stuff
- Generated popup JS and CSS files are in folder dist/. (Online build tool is on documentation page).
- Source files are in folder src/. They include Sass CSS file and js parts (edit them if you wish to submit commit).
- Website (examples & documentation) is in folder website/.
- Documentation page itself is in website/documentation.md (contributions to it are very welcome).
If you used Magnific Popup in some interesting way, or on site of popular brand, I'd be very grateful if you email me a link to it.
Build
To compile Magnific Popup by yourself, first of make sure that you have Node.js, Grunt.js, Ruby and Jekyll installed, then:
-
Copy repository
git clone https://github.com/dimsemenov/Magnific-Popup.git
-
Go inside Magnific Popup folder that you fetched and install Node dependencies
cd Magnific-Popup && npm install
-
Now simply run grunt
to generate JS and CSS in folder dist
and site in folder _site/
.
grunt
Optionally:
- Run
grunt watch
to automatically rebuild script when you change files in src/
or in website/
. - If you don't have and don't want to install Jekyll, run
grunt nosite
to just build JS and CSS files related to popup in dist/
.
License
Script is MIT licensed and free and will always be kept this way. But has a small restriction from me - please do not create public WordPress plugin based on it(or at least contact me before creating it), because I will make it and it'll be open source too (want to get notified?).
Created by @dimsemenov & contributors.
Bugs & contributing
Please report bugs via GitHub and ask general questions through Stack Overflow. Feel free to submit commit pull-request, even the tiniest contributions to the script or to the documentation are very welcome.