zoukankan      html  css  js  c++  java
  • javascript选项卡OOP实现方式

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>基本选项卡</title>
        <style type="text/css">
            #div1 input{background: #ffffff;}
            #div1 input.active{background: yellow;}
            #div1 div{width: 200px; height: 200px; background: red; display: none;}
        </style>
        <script type="text/javascript">
            window.onload = function(){
                var oDiv = document.getElementById('div1');
                var aBtn = oDiv.getElementsByTagName('input');
                var aDiv = oDiv.getElementsByTagName('div');
                for(var i=0;i<aBtn.length;i++)
                {
                    aBtn[i].index = i;
                    aBtn[i].onclick = function(){
                        for(var j=0;j<aBtn.length;j++)
                        {
                            aBtn[j].className = '';
                            aDiv[j].style.display = 'none';
                        }
                        this.className = 'active';
                        aDiv[this.index].style.display = 'block';
                    };
                }
            };
        </script>
    </head>
    <body>
    <div id="div1">
        <input type="button" class="active" value="a"/><input type="button" value="b"/><input type="button" value="c"/>
        <div style="display: block;">1111111</div>
        <div>2222222</div>
        <div>3333333</div>
    </div>
    </body>
    </html>
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>面向对象选项卡</title>
        <style type="text/css">
            #div1 input{background: #ffffff;}
            #div1 input.active{background: yellow;}
            #div1 div{width: 200px; height: 200px; background: red; display: none;}
        </style>
        <script type="text/javascript">
            //window.onload变成构造函数,变量变成属性,函数变成方法
            function TabSwitch(id)
            {
                var _this = this;//_this指的是类TabSwitch实例化的对象
                var oDiv = document.getElementById(id);
                this.aBtn = oDiv.getElementsByTagName('input');
                this.aDiv = oDiv.getElementsByTagName('div');
                for(var i=0;i<this.aBtn.length;i++)
                {
                    this.aBtn[i].index = i;
                    this.aBtn[i].onclick = function(){
                        _this.fnClick(this);//this指的是aBtn[i],
                    };
                }
            }
            TabSwitch.prototype.fnClick = function(oBtn)
            {
                for(var j=0;j<this.aBtn.length;j++)
                {
                    this.aBtn[j].className = '';
                    this.aDiv[j].style.display = 'none';
                }
                //this.className = 'active';
                this.aDiv[oBtn.index].style.display = 'block';
                this.className = 'active';
            }
            window.onload = function()
            {
                var oTabSwitch = new TabSwitch('div1');
            };
        </script>
    </head>
    <body>
    <div id="div1">
        <input type="button" class="active" value="a"/><input type="button" value="b"/><input type="button" value="c"/>
        <div style="display: block;">1111111</div>
        <div>2222222</div>
        <div>3333333</div>
    </div>
    </body>
    </html>
    工欲善其事 必先利其器
  • 相关阅读:
    PHP 单例 工厂模式 类的重载 抽象 接口
    上传文件
    ThinkPHP3.2中if标签
    JS闭包特性 运算符 DOM操作
    循环数组 连接数据库 AJAX
    ThinkPHP
    TP框架
    MVC框架
    类的自动加载,静态属性静态方法
    魔术方法__get()和set函数
  • 原文地址:https://www.cnblogs.com/fengyouqi/p/7767544.html
Copyright © 2011-2022 走看看