Javascript 带有jQuery的CSS选项卡:仅显示当前选项卡的内容
我有一些CSS样式的HTML文件,现在我尝试创建垂直选项卡,但是当页面加载所有内容时,如果我选择任何特定选项卡,则只显示该选项卡的内容,但我担心页面加载时。为什么会显示所有选项卡内容?下面是代码Javascript 带有jQuery的CSS选项卡:仅显示当前选项卡的内容,javascript,jquery,html,css,tabs,Javascript,Jquery,Html,Css,Tabs,我有一些CSS样式的HTML文件,现在我尝试创建垂直选项卡,但是当页面加载所有内容时,如果我选择任何特定选项卡,则只显示该选项卡的内容,但我担心页面加载时。为什么会显示所有选项卡内容?下面是代码 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <title>Follow me!&l
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>Follow me!</title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.3/jquery.min.js" type="text/javascript"></script>
<style type="text/css">
ul.tabs {
margin-top: 20px;
padding: 0;
list-style: none;
height: 32px; /*--Set height of tabs--*/
/*border-bottom: 1px solid #999;
border-left: 1px solid #999;*/
float:left;
}
ul.tabs li a {
text-decoration: none;
color: #000;
font-size: 1.2em;
padding: 0 20px;
border: 1px solid #fff; /*--Gives the bevel look with a 1px white border inside the list item--*/
outline: none;
}
ul.tabs li a:hover {
background: #ccc;
}
html ul.tabs li.active, html ul.tabs li.active a:hover { /*--Makes sure that the active tab does not listen to the hover properties--*/
background: #fff;
border-bottom: 1px solid #fff; /*--Makes the active tab look like it's connected with its content--*/
}
.tab_container {
border: 1px solid #999;
border-top: none;
overflow: hidden;
clear: both;
float: left; width: 100%;
background: #fff;
}
.tab_content {
padding: 20px;
font-size: 1.2em;
}
.spacing {
margin-left:90px;
}
</style>
<script type="text/javascript">
$(document).ready(function() {
//When page loads...
$("ul.tabs li:first-child a").addClass("active").show(); //Activate first tab
$(".tab_content #link1").css("display", "block"); //Show first tab content
//On Click Event
$("ul.tabs li a").click(function() {
$("ul.tabs li a").removeClass("active"); //Remove any "active" class
$(".tab_content div").css("display","none");
$(this).addClass("active"); //Add "active" class to selected tab
var activeTab = $(this).attr("href"); //Find the href attribute value to identify the active tab + content
$(activeTab).fadeIn(); //Fade in the active ID content
return false;
});
});
</script>
</head>
<body>
<ul class="tabs">
<li><a href="#link1" class="tab_content">Link1</a></li>
<li><a href="#link2" class="tab_content">Link2</a></li>
<li><a href="#link3" class="tab_content">Link3</a></li>
</ul>
<div class="tab_content spacing">
<div id="link1">
<p>Link1</p>
</div>
<div id="link2">
<p>Link2</p>
</div>
<div id="link3">
<p>Link3</p>
</div>
</div>
</body>
</html>
跟着我!
ul标签{
边缘顶部:20px;
填充:0;
列表样式:无;
高度:32px;/*--设置选项卡的高度--*/
/*边框底部:1px实心#999;
左边框:1px实心#999*/
浮动:左;
}
ul.lia{
文字装饰:无;
颜色:#000;
字体大小:1.2米;
填充:0 20px;
边框:1px实心#fff;/*--在列表项中提供带有1px白色边框的倒角外观--*/
大纲:无;
}
ul.a:悬停{
背景:#ccc;
}
html ul.tabs li.active,html ul.tabs li.active a:hover{/*--确保活动选项卡不侦听hover属性--*/
背景:#fff;
边框底部:1px solid#fff;/*--使活动选项卡看起来与其内容相连--*/
}
.tab_容器{
边框:1px实心#999;
边界顶部:无;
溢出:隐藏;
明确:两者皆有;
浮动:左侧;宽度:100%;
背景:#fff;
}
.tab_内容{
填充:20px;
字体大小:1.2米;
}
.间距{
左边距:90像素;
}
$(文档).ready(函数(){
//当页面加载时。。。
$(“ul.tabs li:first child a”).addClass(“active”).show();//激活第一个选项卡
$(“.tab_content#link1”).css(“显示”、“块”);//显示第一个选项卡内容
//点击事件
$(“ul.tabs li a”)。单击(函数(){
$(“ul.a”).removeClass(“active”);//删除任何“active”类
$(“.tab_content div”).css(“显示”、“无”);
$(this).addClass(“active”);//将“active”类添加到所选选项卡
var activeTab=$(this).attr(“href”);//查找href属性值以标识活动选项卡+内容
$(activeTab).fadeIn();//淡入活动ID内容
返回false;
});
});
链接1
链接2
链接3
您可能需要使用:
$(".tab_content div")live(,"ready",function(){
.... hide tabs that are not link1
})
或者,由于选项卡需要javascript才能工作,您可以在开始时隐藏它们,并在准备就绪时显示第一个选项卡(只是不要忘记您的noscript标记)尝试将此添加到css中:
div.spacing > div {
display: none;
}
这将隐藏类为间距的div的所有子div
或者,为了更好地进行“优雅的降级”,请将它们隐藏在文档中。就绪功能:
$('div.spacing > div').hide();