要实现这样的功能,点击tab导航ajax动态加载页面,当加载过之后,点击则不再重新加载,直接显示原来加载的页面。

tab页面代码:

<!-- Nav tabs -->
<ul class="nav nav-tabs" role="tablist" id="maintab">
 <li class="active"><a href="#tab1"  onclick='showPage("tab1","tab1.php")'>tab1</a></li>
 <li><a href="#tab2" onclick='showPage("tab2","tab2.php")'>tab2</a></li>
 <li><a href="#tab3" onclick='showPage("tab3","tab3.php")'>tab3</a></li>
 <li><a href="#tab4" onclick='showPage("tab4","tab4.php")'>tab4</a></li>
</ul>

<!-- Tab panes -->
<div class="tab-content">
  <div class="tab-pane active" id="tab1"></div>
  <div class="tab-pane" id="tab2"></div>
  <div class="tab-pane" id="tab3"></div>
  <div class="tab-pane" id="tab4"></div>
</div>

javascript:

<script language="javascript">
var loadimg="./img/load2.gif"; // 加载时的loading图片

function showPage(tabId, url){
$('#maintab a[href="#'+tabId+'"]').tab('show'); // 显示点击的tab页面
if($('#'+tabId).html().length<20){ // 当tab页面内容小于20个字节时ajax加载新页面
$('#'+tabId).html('<br>'+loadimg+' 页面加载中,请稍后...'); // 设置页面加载时的loading图片
$('#'+tabId).load(url); // ajax加载页面
}
}

</script>