I'm developing a web page in which I'm using Twitter's Bootstrap Framework and their Bootstrap Tabs JS. It works great except for a few minor issues, one of which is I do not know how go directly to a specific tab from an external link. For example:
<a href="facility.php#home">Home</a> <a href="facility.php#notes">Notes</a>
should go to the Home tab and the Notes tab respectively when clicked on the links from an external page
Here is my solution to the problem, a bit late perhaps. But it could maybe help others:
// Javascript to enable link to tab var hash = location.hash.replace(/^#/, ''); // ^ means starting, meaning only match the first hash if (hash) { $('.nav-tabs a[href="#' + hash + '"]').tab('show'); } // Change hash for page-reload $('.nav-tabs a').on('shown.bs.tab', function (e) { window.location.hash = e.target.hash; })
UPDATE
For Bootstrap 3, change .on('shown', ...)
to .on('shown.bs.tab', ....)
This is based off of @dubbe answer and this SO accepted answer. It handles the issue with window.scrollTo(0,0)
not working correctly. The problem is that when you replace the url hash on tab shown, the browser will scroll to that hash since its an element on the page. To get around this, add a prefix so the hash doesn't reference an actual page element
// Javascript to enable link to tab var hash = document.location.hash; var prefix = "tab_"; if (hash) { $('.nav-tabs a[href="'+hash.replace(prefix,"")+'"]').tab('show'); } // Change hash for page-reload $('.nav-tabs a').on('shown', function (e) { window.location.hash = e.target.hash.replace("#", "#" + prefix); });
Example of use
If you have tab-pane with id="mytab" you need to put your link like this:
<a href="yoursite.com/#tab_mytab">Go to Specific Tab </a>
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With