zoukankan      html  css  js  c++  java
  • 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{ 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{ 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;  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>
    

      

  • 相关阅读:
    bash :startx command not found
    RHSA-2019:1880-低危: curl 安全和BUG修复更新 及 RHSA-2019:1884-中危: libssh2
    CentOS8 安装后 无法切换中文输入法
    【centOS7】centOS7上普通用户切换root用户,相互切换
    centos8安装图解(超详细教程)
    电导率与土壤盐浓度间的计算公式
    Tlink物联网平台使用(三)
    Wireshark查看https的通讯
    docker中建立私有git服务器[gitlab]
    【转】程序员的生产力始于需求而非工具
  • 原文地址:https://www.cnblogs.com/xl900912/p/4353440.html
Copyright © 2011-2022 走看看