我在我的应用程序中使用Bootstrap药丸:
<div class="container">
<ul class="nav nav-pills">
<li class="active"><a data-target="#home" data-toggle="tab">Home</a></li>
<li><a href="#about" data-toggle="tab">About</a></li>
<li><a href="#contacts" data-toggle="tab">Contacts</a></li>
</ul>
</div>
<div class="tab-content">
<div class="tab-pane active" id="home">Home</div>
<div class="tab-pane" id="about">About</div>
<div class="tab-pane" id="contacts">Contacts</div>
</div>
为了在页面重新加载后保持在同一标签上,我使用以下函数:
$(function() {
$('a[data-toggle="tab"]').on('shown.bs.tab', function (e) {
localStorage.setItem('lastTab', $(this).attr('href'));
});
var lastTab = localStorage.getItem('lastTab');
if (lastTab) {
$('[href="' + lastTab + '"]').tab('show');
}
});
问题是,页面重新加载后,第一个选项卡变为活动1秒,然后它跳转到实际的活动选项卡。我可以保持当前选项卡没有这个'跳转'?
3条答案
按热度按时间vohkndzv1#
这一行:
必须更改为:
你不能引用href而是引用data-target。
这同样适用于:localStorage. setItem.....
固定代码(jsfiddle):
5rgfhyps2#
答案就像ABC一样简单。
我只需要从第一个
<li></li>
标签中删除class=“active”:c86crjj03#
答案很简单:只需从默认选项卡及其内容中删除ACTIVE CLASS。
在JavaScript文件的script标签中: