JS学习笔记 - 普通选项卡(面向过程)

 

疑问:

1. getElementsByTagName 和 getElementsByClassName  的区别? 分别在什么应用场景? 
 
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>普通选项卡</title>
    <style>
    #div1 input{
        background: white;
    }
    #div1 input.active{
        background: yellow;
        /* 这里直接给className为active的标签设置颜色,

            1. 第一个按钮默认是黄色,所以需要先设置。
            2. js只需要先清空所有input的className,再把点击的this按钮 className变成active。
            不应该用js设置颜色式样!错误: aBtn[i].style.background-color = yellow;
         */
    }
    #div1 div{
        width: 200px;
        height: 200px;
        background-color: #ccc;
        display: none;
    }
    </style>

    <script>
    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的index顺序变成数值,以便于后面aDiv使用
            
            aBtn[i].onclick = function()
            {
                for(var i=0; i<aBtn.length; i++)
                {
                    aBtn[i].className = '';          // 先清空 所有按钮 和 div 的样式
                    aDiv[i].style.display = 'none';
                };

                this.className = 'active';         // 把点击的 这个按钮 类名 变成 ‘active’
                
                aDiv[this.index].style.display = 'block'; 
                // 和按钮序号相对应的div,display变成block
                
                // aDiv[this.index]  ==> aBtn[i].index = i
                // 把aBtn的index顺序变成数值,以便于后面aDiv使用  
                //疑问,怎么不能直接写 aDiv[i] ?
            };
        };
    };
    </script>
</head>
<body>
    <div id="div1">
        <input class="active" type="button" value="aaa">
        <!-- 默认把第一个按钮的class设置为active,即背景色为yellow -->
        <input type="button" value="bbb">
        <input type="button" value="ccc">

        <div style="display: block";>mfdkjgmdkgm</div>
        <!-- 默认把第一个div的display设置为block-->
        <div>我梦见你梦见我</div>
        <div>14597825</div>
    </div>    
</body>
</html>

 

错误1:

<script>
    window.onload = function ()
    {
        var aBtn = document.getElementsByTagName('input');
        var oDiv = document.getElementById('div1');
        var aDiv = oDiv.getElementsByTagName('div');

        for(var i=0; i<aBtn.length; i++)
        {
            aBtn[i].index = i;

            aBtn[i].onclick = function()
            {
                for (var i=0; i<aBtn.length;i++) {
                        aBtn[i].className = '';
                        aDiv[i].style.display = 'none';
                    }
                // aBtn[i].className = ''; 
                // 不是直接在onclick事件里 用 aBtn[i] 给其他所有按钮、div设置样式。
                // aBtn[i] 只表示单个,再用一个for循环来处理,才表示全部。

                this.className = 'active';
                aDiv[this.index].style.display = 'block';
            }            
        }
    }
    </script>

 

 

错误2:

<script>
    window.onload = function()
    {
        var aBtn = document.getElementsByTagName('input');

        for(i=0; i<aBtn.length; i++)
        {
            aBtn[i].onclick = function()
            {
                //aBtn[i].className = 'active'; 
this.className = 'active'; // 当前事件作用于 this, 所以给 this 加 className }; }; }; </script>
posted @ 2018-12-29 16:18  CarpenterZoe  阅读(160)  评论(0编辑  收藏  举报