I want to programmable switch tabs (using bootstrap 5). Bootsrap docs say:
As a best practice, we recommend using elements for the tabs, as these are controls that trigger a dynamic change, rather than links that navigate to a new page or location.
So I want use buttons instead links. Code:
JavaScript
x
4
1
$("#mybut").click(function() {
2
var sel = document.querySelector('#nav-tab-manager')
3
bootstrap.Tab.getInstance(sel).show()
4
})
JavaScript
1
24
24
1
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/js/bootstrap.bundle.min.js"></script>
2
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" rel="stylesheet"/>
3
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
4
<nav>
5
6
<div class="nav nav-tabs" id="nav-tab" role="tablist">
7
<button class="nav-link active" id="nav-tabs-order" data-bs-toggle="tab" data-bs-target="#tabs-1" type="button" role="tab" aria-controls="tabs-1" aria-selected="true">Orders
8
</button>
9
<button class="nav-link" id="nav-tab-manager" data-bs-toggle="tab" data-bs-target="#tabs-2" type="button" role="tab" aria-controls="tabs-2" aria-selected="false">Managers
10
</button>
11
</div>
12
</nav>
13
14
15
<div class="tab-content" id="myTabContent">
16
<div class="tab-pane fade show active" id="tabs-1" role="tabpanel" aria-labelledby="tabs-tab1">
17
Orders
18
</div>
19
<div class="tab-pane fade" id="tabs-2" role="tabpanel" aria-labelledby="tabs-2">
20
Managers
21
</div>
22
</div>
23
24
<button type="button" class="btn btn-primary" id="mybut">Want switch to manager</button>
Problem is wrong selector. But I have no idea why.
Advertisement
Answer
You’ll want to use getOrCreateInstance
instead because the Tabs aren’t being first initialized via JS.
JavaScript
1
5
1
$("#mybut").click(function() {
2
var sel = document.querySelector('#nav-tab-manager')
3
bootstrap.Tab.getOrCreateInstance(sel).show()
4
})
5