多個選項卡

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>選項卡(IE,FF,Opera,Safari,Chrome)</title>
<style type="text/css">
#tab_container1{width:600px;text-align:left;}
.cls_tab_nav{height:26px;overflow:hidden;font-size:12px;text-align:left;background:url(http://www.dovapour.com.cn/article/testImages/line_bg.jpg) repeat-x bottom;}
.cls_tab_nav ul{font-size:12px;margin:0;padding:0;}
.cls_tab_nav_li{background:url(http://www.dovapour.com.cn/article/testImages/tab_bg.jpg) no-repeat -157px 0;width:157px;height:26px;line-height:26px;float:left;display:inline;overflow:hidden;text-align:center;cursor:pointer;}
.cls_tab_nav_li_first{background-position:0px 0px;}
.cls_tab_nav_li a{text-decoration:none;color:#444;}
.cls_tab_body{border:1px solid #FFAE1E;border-top:none;min-height:320px;}
.cls_div{display:none;font-size:12px;}
</style>
</head>
<body>
<div id="tab_container2" style="width:472px;">
 <div class="cls_tab_nav">
  <ul>
   <li class="cls_tab_nav_li cls_tab_nav_li_first"><a href="#">選項卡1</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡2</a></li>
  </ul>
 </div>
 <div class="cls_tab_body">
  <div class="cls_div" style="display:block;">選項卡1</div>
  <div class="cls_div">選項卡2</div>
 </div>
</div>
<hr />
<div id="tab_container1">
 <div class="cls_tab_nav">
  <ul>
   <li class="cls_tab_nav_li cls_tab_nav_li_first"><a href="#">選項卡1</a></li>
   <li class="cls_tab_nav_li"><a href="#">百度</a></li>
   <li class="cls_tab_nav_li"><a href="#">js</a></li>
  </ul>
 </div>
 <div class="cls_tab_body">
  <div class="cls_div" style="display:block;">選項卡1</div>
  <div class="cls_div">選項卡2</div>
  <div class="cls_div">http://www.dovapour.com.cn/</div>
 </div>
</div>
<hr />
<div id="tab_container3" style="width:700px;">
 <div class="cls_tab_nav">
  <ul>
   <li class="cls_tab_nav_li cls_tab_nav_li_first"><a href="#">選項卡1</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡2</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡3</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡4</a></li>
  </ul>
 </div>
 <div class="cls_tab_body">
  <div class="cls_div" style="display:block;">選項卡1</div>
  <div class="cls_div">選項卡2</div>
  <div class="cls_div">選項卡3</div>
  <div class="cls_div">選項卡4http://www.dovapour.com.cn/</div>
 </div>
</div>
<hr />
<div id="tab_container4" style="width:900px;">
 <div class="cls_tab_nav">
  <ul>
   <li class="cls_tab_nav_li cls_tab_nav_li_first"><a href="#">選項卡1</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡2</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡3</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡4</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡5</a></li>
  </ul>
 </div>
 <div class="cls_tab_body">
  <div class="cls_div" style="display:block;">選項卡1</div>
  <div class="cls_div">選項卡2</div>
  <div class="cls_div">選項卡3</div>
  <div class="cls_div">選項卡4</div>
  <div class="cls_div">選項卡5 http://www.dovapour.com.cn/</div>
 </div>
</div>
<hr />
<div id="tab_container5" style="width:942px;">
 <div class="cls_tab_nav">
  <ul>
   <li class="cls_tab_nav_li cls_tab_nav_li_first"><a href="#">選項卡1</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡2</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡3</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡4</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡5</a></li>
   <li class="cls_tab_nav_li"><a href="#">選項卡6</a></li>
  </ul>
 </div>
 <div class="cls_tab_body">
  <div class="cls_div" style="display:block;">選項卡1</div>
  <div class="cls_div">選項卡2</div>
  <div class="cls_div">選項卡3</div>
  <div class="cls_div">選項卡4</div>
  <div class="cls_div">選項卡5</div>
  <div class="cls_div">選項卡6</div>
 </div>
</div>
<script type="text/javascript">
try{
 document.execCommand("BackgroundImageCache", false, true);
}catch(e){}
function $(element){
 if(arguments.length>1){
  for(var i=0,elements=[],length=arguments.length;i<length;i++)
   elements.push($(arguments[i]));
  return elements;
 }
 if(typeof element=="string")
  return document.getElementById(element);
 else
  return element;
}
var Class={
 create:function(){
  return function(){
   this.initialize.apply(this,arguments);
  }
 }
}
Object.extend=function(destination,source){
 for(var property in source){
  destination[property]=source[property];
 }
 return destination;
}
var tabMenu=Class.create();
tabMenu.prototype={
 initialize:function(container,selfOpt,otherOpt){
  this.container=$(container);
  /*
   利用Object的extend方法來實現對默認屬性的覆蓋.
   如果初始化選項卡時,沒有設置選項卡的屬性,則默認屬性
  */
  var selfOptions=Object.extend({fontWeight:"bold",fontSize:"12px",color:"#FFBC44"},selfOpt||{});
  var otherOptions=Object.extend({fontWeight:"normal",fontSize:"12px",color:"#666"},otherOpt||{});
  //用for循環得到objs數組,主要是爲了兼容非IE瀏覽器把空白也當作子對象
  for(var i=0,length=this.container.childNodes.length,objs=[];i<length;i++){
   if(this.container.childNodes[i].nodeType==1)
    objs.push(this.container.childNodes[i]);
  }
  var tabArray=objs[0].getElementsByTagName("li");
  //用for循環得到divArray數組,主要是爲了兼容非IE瀏覽器把空白也當作子對象
  var divArray=new Array();
  for(i=0,length=objs[1].childNodes.length;i<length;i++){
   if(objs[1].childNodes[i].nodeType==1)
    divArray.push(objs[1].childNodes[i]);
  }
 
  for(i=0,length=tabArray.length;i<length;i++){
   tabArray[i].length=length;
   tabArray[i].index=i;
   tabArray[i].οnmοuseοver=function(){
    //其它選項卡樣式設置
    for(var j=0;j<this.length;j++){
     tabArray[j].style.backgroundPosition="-"+tabArray[j].offsetWidth+"px 0";
     for(var property in selfOptions){
      tabArray[j].firstChild.style[property]=otherOptions[property];
     }
    }
    //當前選項卡樣式
    this.style.backgroundPosition="0 0";
    for(var property in selfOptions){
     this.firstChild.style[property]=selfOptions[property];
     /*
      注意this.style.property和selfOptions.property的用法錯誤
      style.fontWeight正確
      style["fontWeight"]正確
      style["font-weight"]錯誤
     */
    }
    //隱藏其它選項卡
    for(j=0;j<this.length;j++){
     divArray[j].style.display="none";
    }
    //顯示當前選項卡
    divArray[this.index].style["display"]="block";
   }
  }
 }
}
/*
第一個參數是必選項,第二個參數是設置當前選項卡的樣式,可選項,第三個參數是其它選項卡的樣式.
例如:
var tab2=new tabMenu("tab_con2",{color:"##FFBC44",fontWeight:"bold",fontSize:"12px"});
需要注意的是第二個和第三個參數的寫法.
因爲直接用CSS的寫法font-weight將導致JS(對象的屬性命名)語法出錯,所以只能用JS的寫法.把CSS中的"-"去掉,而後"-"符號後面的單詞的首子母大寫.
例如 font-size寫成 fontSize, text-decoration寫成textDecoration
*/
var tab1=new tabMenu("tab_container1",{fontSize:"14px",color:"#FFBC44",fontWeight:"bold"},{fontWeight:"normal",color:"#666"});
var tab2=new tabMenu("tab_container2");
var tab3=new tabMenu("tab_container3",{textDecoration:"underline"},{textDecoration:"none"});
var tab4=new tabMenu("tab_container4",{fontWeight:"normal"});
var tab5=new tabMenu("tab_container5");
</script>
</body>
</html></font>

<a href="http://js.alixixi.com/">歡迎訪問阿里西西網頁特效代碼站,js.alixixi.com</a>

發佈了127 篇原創文章 · 獲贊 6 · 訪問量 14萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章