js面向对象+一般方法的选项卡

<!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>js面向对象+一般方法的选项卡</title>

<style type="text/css">

* { padding:0px; margin:0px;  }

#tab,#tab2{ width:450px;  margin:20px auto; font-size:12px; height:245px;}

.tab_inner { list-style:none;  border:1px solid #000; overflow:hidden; background:#000000; color:#FFFFFF; border-top-left-radius:5px; border-top-right-radius:5px; height:30px}

.tab_inner li{ width:80px; height:30px; text-align:center; line-height:30px; float:left; cursor:pointer; }

.tab_inner .hover{ background:#999; color:#000000;}

.content_{ border-bottom:1px #000000 solid; border-right:1px #000000 solid; border-left:1px #000000 solid; border-bottom-right-radius:5px; border-bottom-left-radius:5px; box-shadow:3px 3px 8px #666666;  width:448px; }

.content_ .summary{ display:none; clear:both }

.content_ .summary ul { padding-left: 30px; list-style-type:armenian line-height:25px;}

</style>

</head>



<body>

<div id="tab2">

    <ul class="tab_inner">

        <li class="hover">栏目一</li>

        <li>栏目二</li>

        <li>栏目三</li>    

        <li>栏目四</li>

    </ul>

    <div class="content_">

        <div class="summary" style="display:block;">

          <ul>

            <li>网页特效原理分析</li>

            <li>响应用户操作</li>

            <li>提示框效果</li>

            <li>事件驱动</li>

            <li>元素属性操作</li>

            <li>动手编写第一个JS特效</li>

            <li>引入函数</li>

            <li>网页换肤效果</li>

            <li>展开/收缩播放列表效果</li>

          </ul>

        </div>

        <div class="summary">

            <ul>

                <li>改变网页背景颜色</li>

                <li>函数传参</li>

                <li>高重用性函数的编写</li>

                <li>126邮箱全选效果</li>

                <li>循环及遍历操作</li>

                <li>调试器的简单使用</li>

                <li>典型循环的构成</li>

                <li>for循环配合if判断</li>

                <li>className的使用</li>

                <li>innerHTML的使用</li>

                <li>戛纳印象效果</li>

                <li>数组</li>

                <li>字符串连接</li>

            </ul>

        </div>

        <div class="summary">

            <ul>

                <li>JavaScript组成:ECMAScript、DOM、BOM,JavaScript兼容性来源</li>

                <li>JavaScript出现的位置、优缺点</li>

                <li>变量、类型、typeof、数据类型转换、变量作用域</li>

                <li>闭包:什么是闭包、简单应用、闭包缺点</li>

                <li>运算符:算术、赋值、关系、逻辑、其他运算符</li>

                <li>程序流程控制:判断、循环、跳出</li>

                <li>命名规范:命名规范及必要性、匈牙利命名法</li>

                <li>函数详解:函数构成、调用、事件、传参数、可变参、返回值</li>

                <li>定时器的使用:setInterval、setTimeout</li>

                <li>定时器应用:站长站导航效果</li>

                <li>定时器应用:自动播放的选项卡</li>

                <li>定时器应用:数码时钟</li>

                <li>程序调试方法</li>

            </ul>

        </div>

        <div class="summary">

            <ul>

                <li>over...</li>

            </ul>

        </div>

    </div>

</div>

<div id="tab">

    <ul class="tab_inner">

        <li class="hover">栏目一</li>

        <li>栏目二</li>

        <li>栏目三</li>    

        <li>栏目四</li>

    </ul>

    <div class="content_">

        <div class="summary" style="display:block;">

            <ul>

                <li>网页特效原理分析</li>

                <li>响应用户操作</li>

                <li>提示框效果</li>

                <li>事件驱动</li>

                <li>元素属性操作</li>

                <li>动手编写第一个JS特效</li>

                <li>引入函数</li>

                <li>网页换肤效果</li>

                <li>展开/收缩播放列表效果</li>

            </ul>

        </div>

        <div class="summary">

            <ul>

                <li>改变网页背景颜色</li>

                <li>函数传参</li>

                <li>高重用性函数的编写</li>

                <li>126邮箱全选效果</li>

                <li>循环及遍历操作</li>

                <li>调试器的简单使用</li>

                <li>典型循环的构成</li>

                <li>for循环配合if判断</li>

                <li>className的使用</li>

                <li>innerHTML的使用</li>

                <li>戛纳印象效果</li>

                <li>数组</li>

                <li>字符串连接</li>

            </ul>

        </div>

        <div class="summary">

            <ul>

                <li>JavaScript组成:ECMAScript、DOM、BOM,JavaScript兼容性来源</li>

                <li>JavaScript出现的位置、优缺点</li>

                <li>变量、类型、typeof、数据类型转换、变量作用域</li>

                <li>闭包:什么是闭包、简单应用、闭包缺点</li>

                <li>运算符:算术、赋值、关系、逻辑、其他运算符</li>

                <li>程序流程控制:判断、循环、跳出</li>

                <li>命名规范:命名规范及必要性、匈牙利命名法</li>

                <li>函数详解:函数构成、调用、事件、传参数、可变参、返回值</li>

                <li>定时器的使用:setInterval、setTimeout</li>

                <li>定时器应用:站长站导航效果</li>

                <li>定时器应用:自动播放的选项卡</li>

                <li>定时器应用:数码时钟</li>

                <li>程序调试方法</li>

            </ul>

        </div>

        <div class="summary">

            <ul>

                <li>over...</li>

            </ul>

        </div>

    </div>

</div>

<script type="text/javascript">

//面向对象版本选项卡

    function Tab(obj,type){

        this.tab=document.getElementById(obj);

        this.tab_inner=this.getByClass("tab_inner",obj)[0];

        this.tab_li=this.tab_inner.getElementsByTagName("li");

        this.content_=this.getByClass("content_",obj)[0];

        this.summary=this.getByClass("summary",this.content_);

        var that=this;

        for (var i=0;i<this.tab_li.length;i++){

            this.tab_li[i].index=i;

            Tab.prototype.addHandler(this.tab_li[i],type,function(){that.switch(this.index);});

        }

    }

    Tab.prototype.getByClass=function(className,parents){

        parents=parents||document;

        if(parents.getElementsByClassName){

            return parents.getElementsByClassName(className);

        }

        var nodes=document.getElementsByTagName("*");

        ret=[];

        for (var i=0;i<nodes.length;i++){

            if(hasClass(nodes[i],className)){

                ret.push(nodes[i]);

            }

        }

        return ret;

    }

    Tab.prototype.hasClass=function(node,className){

        var names=node.className.split(/\st/);

        for(var i=0;i<names.lemgth;i++){

            if(names[i]==className){

                return true;

            }

        }

        return false;

    }

    Tab.prototype.addHandler=function(obj,type,fn){

        if (obj.attachEvent) 

        {

            obj['e'+type+fn] = fn;

            obj[type+fn] = function(){obj['e'+type+fn]( window.event );}

            obj.attachEvent( 'on'+type, obj[type+fn] );

        } else{

            obj.addEventListener( type, fn, false ); 

        }

    }

    Tab.prototype.switch=function(n){

        for (var i=0;i<this.tab_li.length;i++){

            this.tab_li[i].className="";

            this.summary[i].style.display="none";

        }

        this.tab_li[n].className="hover";

        this.summary[n].style.display="block";

    }

</script>

<script type="text/javascript">

    window.onload=function(){

        var tab=document.getElementById("tab")

        new Tab(tab,"mouseover");

        var tab2=document.getElementById("tab2")

        new Tab(tab2,"click");

    }

</script>

<!--script type="text/javascript">

//一般做法版本的选项卡

window.onload=function(){

    var tab=document.getElementById("tab");

    var tab_inner=getByClass("tab_inner",tab)[0];

    var tab_li=tab_inner.getElementsByTagName("li");

    var content_=getByClass("content_",tab)[0];

    var summary=getByClass("summary",content_);

    function getByClass(className,parents){   //用className获取元素

        parents=parents||document;

        if(parents.getElementsByClassName){

            return parents.getElementsByClassName(className);

        }

        var nodes=document.getElementsByTagName("*");

        ret=[];

        for (var i=0;i<nodes.length;i++){

            if(hasClass(nodes[i],className)){

                ret.push(nodes[i]);

            }

        }

        return ret;

    }

    function hasClass(node,className){

        var names=node.className.split(/\st/);

        for(var i=0;i<names.lemgth;i++){

            if(names[i]==className){

                return true;

            }

        }

        return false;

    }

    for (var i=0;i<tab_li.length;i++){   //效果实现

        tab_li[i].index=i;

        tab_li[i].onmouseover=function(){

            for (i=0;i<tab_li.length;i++){

                tab_li[i].className="";

                summary[i].style.display="none";

            }

            this.className="hover";

            summary[this.index].style.display="block";

        }

    }

}

</script-->

</body>

</html>

  

你可能感兴趣的:(面向对象)