Bootstrap Q&A Logo
Bootstrap Q&A Part of the Q&A Network
Real Questions. Clear Answers.
Ask any question about Bootstrap here... and get an instant response.
Q&A Balloon Q&A Logo
Post this Question & Answer:

How do I close dropdowns on click outside when using custom JS?

Asked on Aug 20, 2025

Answer

To close dropdowns when clicking outside of them using custom JavaScript, you can add an event listener to the document that checks if the click target is outside the dropdown. If it is, you manually hide the dropdown.
<!-- BEGIN COPY / PASTE -->
        <div class="dropdown">
            <button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenuButton" data-bs-toggle="dropdown" aria-expanded="false">
                Dropdown button
            </button>
            <ul class="dropdown-menu" aria-labelledby="dropdownMenuButton">
                <li><a class="dropdown-item" href="#">Action</a></li>
                <li><a class="dropdown-item" href="#">Another action</a></li>
                <li><a class="dropdown-item" href="#">Something else here</a></li>
            </ul>
        </div>

        <script>
            document.addEventListener('click', function(event) {
                var dropdown = document.querySelector('.dropdown');
                var isClickInside = dropdown.contains(event.target);

                if (!isClickInside) {
                    var dropdownMenu = dropdown.querySelector('.dropdown-menu');
                    if (dropdownMenu.classList.contains('show')) {
                        bootstrap.Dropdown.getInstance(dropdownMenu).hide();
                    }
                }
            });
        </script>
        <!-- END COPY / PASTE -->
Additional Comment:
  • The code uses Bootstrap's JavaScript API to hide the dropdown.
  • The `document.addEventListener('click', ...)` listens for clicks anywhere on the page.
  • `dropdown.contains(event.target)` checks if the click was inside the dropdown.
  • If the click is outside, it hides the dropdown using Bootstrap's `Dropdown.getInstance().hide()` method.
  • Ensure that Bootstrap's JavaScript is properly included in your project for this to work.
✅ Answered with Bootstrap 5 best practices.
← Back to All Questions

Q&A Network
The Q&A Network
Bootstrap
Ask Questions / Get Answers about Bootstrap!
Performance
Ask Questions / Get Answers about Web Vitals!
Networking
Ask Questions / Get Answers about Networking!
CSS
Ask Questions / Get Answers about CSS!
HTML
Ask Questions / Get Answers about HTML!
Graphic Design
Ask Questions / Get Answers about Graphic Design!
Podcasting
Ask Questions / Get Answers about Podcasting!
AI Video
Ask Questions / Get Answers about AI Video!
SEO
Ask Questions / Get Answers about SEO!
Creative Writing
Ask Questions / Get Answers about Creative Writing!
VR & AR
Ask Questions / Get Answers about VR & AR!
UI/UX Design
Ask Questions / Get Answers about UI/UX Design!
Web Languages
Ask Questions / Get Answers about Web Languages!
Sound Design
Ask Questions / Get Answers about Sound Design!
Quantum
Ask Questions / Get Answers about Quantum Computing!
Security
Ask Questions / Get Answers about Website Security!
JavaScript
Ask Questions / Get Answers about JavaScript!
Film Production
Ask Questions / Get Answers about Film Production!
AI Images
Ask Questions / Get Answers about AI Images!
Data Science
Ask Questions / Get Answers about Data Science!
Animation
Ask Questions / Get Answers about Animation!
Web Development
Ask Questions / Get Answers about Web Development!
AI
Ask Questions / Get Answers about AI!
3D Design
Ask Questions / Get Answers about 3D Design!
Chatbots
Ask Questions / Get Answers about Chatbots!
Robotics
Ask Questions / Get Answers about Robotics!
AI Education
Ask Questions / Get Answers about AI Education!
Motion Graphics
Ask Questions / Get Answers about Motion Graphics!
AI Business
Ask Questions / Get Answers about AI Business!
AI Coding
Ask Questions / Get Answers about AI Coding!
AI Ethics
Ask Questions / Get Answers about AI Ethics!
Analytics
Ask Questions / Get Answers about Analytics!
Monetization
Ask Questions / Get Answers about Ad & Monetization!
DevOps
Ask Questions / Get Answers about DevOps!
WordPress
Ask Questions / Get Answers about WordPress!
Web Hosting
Ask Questions / Get Answers about Hosting!
AI Design
Ask Questions / Get Answers about AI Design!
AI Audio
Ask Questions / Get Answers about AI Audio!
Photography
Ask Questions / Get Answers about Photography!
Tailwind
Ask Questions / Get Answers about Tailwind!
AI Marketing
Ask Questions / Get Answers about AI Marketing!
Illustration
Ask Questions / Get Answers about Illustration!
Cybersecurity
Ask Questions / Get Answers about Cybersecurity!
Video Editing
Ask Questions / Get Answers about Video Editing!
AI Writing
Ask Questions / Get Answers about AI Writing!
MobileDev
Ask Questions / Get Answers about Mobile Developement!
Cloud Computing
Ask Questions / Get Answers about Cloud Computing!
IoT
Ask Questions / Get Answers about IoT!