我正在寻找有关引导选项卡的帮助。
我有带有面板的引导程序选项卡,希望该选项卡在刷新后保持打开状态。我们正在进行许多事情,但是由于我们需要通过NinjaForms输入新数据,因此这是最需要的。
无论如何。这是我找到的解决方案,但由于某种原因我无法使其正常工作。
TABS
<div class="panel with-nav-tabs panel-default">
<div class="panel-heading" style="z-index:998;">
<ul class="nav nav-tabs" id="myTab">
<li class="active"><a href="#tab1overview" data-toggle="tab"><i
class="fa fa-building" style="color:#50AE54"></i> Client Overview</a> .
</li>
<li><a href="#tab2sites" data-toggle="tab"><i class="fa fa-
sitemap" style="color:#1DB2C8"></i> Sites</a></li>
<li><a href="#tab3users" data-toggle="tab"><i class="fa fa-user-
plus" style="color:#FC5830"></i> Users</a></li>
<li><a href="#tab4assets" data-toggle="tab"><i class="fa fa-
desktop" style="color:#2C98F0"></i> Assets</a></li>
<li class="dropdown">
<a href="#" data-toggle="dropdown"><i class="fa fa-wrench"
style="color:#333333"></i> Services <span class="caret"></span></a>
<ul class="dropdown-menu" role="menu">
<li><a href="#tab11internal" data-toggle="tab"><i class="fa
fa-wrench" style="color:#333333"></i> Internal Services</a></li>
<li><a href="#tab12external" data-toggle="tab"><i class="fa
fa-wrench" style="color:#333333"></i> External Services</a></li>
</ul>
</li>
<li class="dropdown">
<a href="#" data-toggle="dropdown"><i class="fa fa-wrench"
style="color:#333333"></i> Web Services <span class="caret"></span></a>
<ul class="dropdown-menu" role="menu">
<li><a href="#tab6webhosting" data-toggle="tab"><i class="fa
fa-wrench" style="color:#333333"></i> Web Hosting</a></li>
<li><a href="#tab7domains" data-toggle="tab"><i class="fa
fa-wrench" style="color:#333333"></i> Domains</a></li>
<li><a href="#tab8crushftp" data-toggle="tab"><i class="fa
fa-wrench" style="color:#333333"></i> SFTP</a></li>
</ul>
</li>
<li class="dropdown">
<a href="#" data-toggle="dropdown"><i class="fa fa-
certificate" style="color:#333333"></i> Licenses <span
class="caret"></span>
</a>
<ul class="dropdown-menu" role="menu">
<li><a href="#tab9email" data-toggle="tab"><i class="fa fa-
certificate" style="color:#333333"></i> eMail</a></li>
</ul>
</li>
<li><a href="#tab10faq" data-toggle="tab"><i class="fa fa-
question" style="color:#1DB2C8"></i> FAQ</a></li>
<!-- Commented out for now <li><a href="#tab10migrations" data-
toggle="tab"><i class="fa fa-rocket" style="color:#2C98F0"></i>
Migrations</a></li> -->
</ul>
</div>
JS
$(function() {
$('a[data-toggle="tab"]').on('click', function(e) {
window.localStorage.setItem('activeTab', $(e.target).attr('href'));
});
var activeTab = window.localStorage.getItem('activeTab');
if (activeTab) {
$('#myTab a[href="' + activeTab + '"]').tab('show');
window.localStorage.removeItem("activeTab");
}
});
WP功能
wp_enqueue_script( 'tabs-refresh',
get_template_directory_uri().'/library/js/tabs.js', array( 'jquery' ),
'1.0.0', false );
只需添加即可,只需检查Chrome中的控制台即可。我发现了:
任何帮助将不胜感激。
谢谢
答案 0 :(得分:2)
默认情况下,当您将jQuery放入Wordpress时,必须使用jQuery, 且不使用$(这是为了与其他库兼容)。
请参阅:TypeError: $ is not a function when calling jQuery function
执行您的功能:
(function($){
[...]
})(jQuery);
所以:
(function($){
$('a[data-toggle="tab"]').on('click', function(e) {
window.localStorage.setItem('activeTab', $(e.target).attr('href'));
});
var activeTab = window.localStorage.getItem('activeTab');
if (activeTab) {
$('#myTab a[href="' + activeTab + '"]').tab('show');
window.localStorage.removeItem("activeTab");
}
})(jQuery);
答案 1 :(得分:0)
在将jQuery和WordPress结合使用时,由于兼容性,您必须使用jQuery
而不是$
如果要使用document.ready,可以将$作为参数传递给函数:
jQuery(function ($) {
// Your code
});
答案 2 :(得分:0)
我真的想通了。
只需将其添加到标签中即可;
<li><a href="#tab11internal" **role="tab"** data-toggle="tab"><i class="fa fa-
wrench" style="color:#333333"></i> Internal Services</a></li>