Bootstrap Q&A Logo
Bootstrap Q&A Part of the Q&A Topic Learning 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
Real Questions. Clear Answers.
Bootstrap
Ask Questions / Get Answers about Bootstrap!
AI Design
Ask Questions / Get Answers about AI Design!
AI Education
Ask Questions / Get Answers about AI Education!
Sound Design
Ask Questions / Get Answers about Sound Design!
Web Development
Ask Questions / Get Answers about Web Development!
Animation
Ask Questions / Get Answers about Animation!
Tailwind
Ask Questions / Get Answers about Tailwind!
Performance
Ask Questions / Get Answers about Web Vitals!
AI Coding
Ask Questions / Get Answers about AI Coding!
3D Design
Ask Questions / Get Answers about 3D Design!
Robotics
Ask Questions / Get Answers about Robotics!
Video Editing
Ask Questions / Get Answers about Video Editing!
VR & AR
Ask Questions / Get Answers about VR & AR!
AI Writing
Ask Questions / Get Answers about AI Writing!
Monetization
Ask Questions / Get Answers about Ad & Monetization!
Illustration
Ask Questions / Get Answers about Illustration!
HTML
Ask Questions / Get Answers about HTML!
Networking
Ask Questions / Get Answers about Networking!
Security
Ask Questions / Get Answers about Website Security!
Web Languages
Ask Questions / Get Answers about Web Languages!
AI Audio
Ask Questions / Get Answers about AI Audio!
Podcasting
Ask Questions / Get Answers about Podcasting!
Web Hosting
Ask Questions / Get Answers about Hosting!
Data Science
Ask Questions / Get Answers about Data Science!
DevOps
Ask Questions / Get Answers about DevOps!
CSS
Ask Questions / Get Answers about CSS!
Motion Graphics
Ask Questions / Get Answers about Motion Graphics!
Film Production
Ask Questions / Get Answers about Film Production!
MobileDev
Ask Questions / Get Answers about Mobile Developement!
JavaScript
Ask Questions / Get Answers about JavaScript!
Photography
Ask Questions / Get Answers about Photography!
Digital Burnout
Ask Questions / Get Answers about Digital Burnout!
Business Finance
Ask Questions / Get Answers about Business Finance!
AI Video
Ask Questions / Get Answers about AI Video!
Social Media Psychology
Ask Questions / Get Answers about Social Media Psychology!
Chatbots
Ask Questions / Get Answers about Chatbots!
UI/UX Design
Ask Questions / Get Answers about UI/UX Design!
IoT
Ask Questions / Get Answers about IoT!
Graphic Design
Ask Questions / Get Answers about Graphic Design!
AI Business
Ask Questions / Get Answers about AI Business!
Nursing
Ask Questions / Get Answers about Nursing!
Analytics
Ask Questions / Get Answers about Analytics!
AI
Ask Questions / Get Answers about AI!
Creative Writing
Ask Questions / Get Answers about Creative Writing!
AI Ethics
Ask Questions / Get Answers about AI Ethics!
AI Marketing
Ask Questions / Get Answers about AI Marketing!
SEO
Ask Questions / Get Answers about SEO!
Cloud Computing
Ask Questions / Get Answers about Cloud Computing!
Cybersecurity
Ask Questions / Get Answers about Cybersecurity!
AI Images
Ask Questions / Get Answers about AI Images!
Quantum
Ask Questions / Get Answers about Quantum Computing!
WordPress
Ask Questions / Get Answers about WordPress!