我是网页设计的初学者。我需要一些专业人士帮我解决这个问题。
下面是我用来创建TABS的JS。我已经更改了默认选项卡,但是我仍然无法弄清楚如何更改默认选项卡页面。请帮忙 !!!
<script type="text/javascript">
//<![CDATA[
var tabLinks = new Array();
var contentDivs = new Array();
function init() {
// Grab the tab links and content divs from the page
var tabListItems = document.getElementById('tabs').childNodes;
for ( var i = 0; i < tabListItems.length; i++ ) {
if ( tabListItems[i].nodeName == "LI" ) {
var tabLink = getFirstChildWithTagName( tabListItems[i], 'A' );
var id = getHash( tabLink.getAttribute('href') );
tabLinks[id] = tabLink;
contentDivs[id] = document.getElementById( id );
}
}
// Assign onclick events to the tab links, and
// highlight the first tab
var i = 0;
for ( var id in tabLinks ) {
tabLinks[id].onclick = showTab;
tabLinks[id].onfocus = function() { this.blur() };
if ( i == 0 ) tabLinks["order"].className = 'selected';
i++;
}
// Hide all content divs except the first
var i = 0;
for ( var id in contentDivs ) {
if ( i != 0 ) contentDivs[id].className = 'tabContent hide';
i++;
}
}
function showTab() {
var selectedId = getHash( this.getAttribute('href') );
// Highlight the selected tab, and dim all others.
// Also show the selected content div, and hide all others.
for ( var id in contentDivs ) {
if ( id == selectedId ) {
tabLinks[id].className = 'active';
contentDivs[id].className = 'tabContent';
} else {
tabLinks[id].className = '';
contentDivs[id].className = 'tabContent hide';
}
}
// Stop the browser following the link
return false;
}
function getFirstChildWithTagName( element, tagName ) {
for ( var i = 0; i < element.childNodes.length; i++ ) {
if ( element.childNodes[i].nodeName == tagName ) return element.childNodes[i];
}
}
function getHash( url ) {
var hashPos = url.lastIndexOf ( '#' );
return url.substring( hashPos + 1 );
}
//]]>
</script>
这是标签列表
<ul id="tabs">
<li><a href="#features">Product Features</a></li>
<li><a class="selected" href="#order">Order UNIFY Sutures</a> </li>
<li><a href="#spec">Specifications</a></li>
<li><a href="#testi">Testimonials</a></li>
<li><a href="#overview">Suture Overview</a></li>
</ul>
答案 0 :(得分:0)
在此处更改您的代码
// Hide all content divs except the first
var i = 0;
for ( var id in contentDivs ) {
if ( i != 0 ) contentDivs[id].className = 'tabContent hide';
i++;
}
if子句if ( i != 0 )
中的零定义了活动标签页。
您还可以查看jquery ui tabs哪个可以做您想要的并且易于使用。
答案 1 :(得分:0)
用以下代码替换showTab函数:
function showTab() {
var selectedId = getHash( this.getAttribute('href') );
selectTab(selectedId);
return false;
}
function selectTab(selectedId) {
// Highlight the selected tab, and dim all others.
// Also show the selected content div, and hide all others.
for ( var id in contentDivs ) {
if ( id == selectedId ) {
tabLinks[id].className = 'active';
contentDivs[id].className = 'tabContent';
} else {
tabLinks[id].className = '';
contentDivs[id].className = 'tabContent hide';
}
}
}
然后,要选择特定选项卡,请调用以下内容:
selectTab('spec');
编辑:更改了selectTab('#spec');选择Tab('spec');