tab选项卡的实现

tab选项卡的实现

会用到原生js的dom操作
这是效果图

html
<body>
    <div id="tab">
        <div id="tab_header">
            <ul>
                <li class="seclect">1</li>
                <li>2</li>
                <li>3</li>
                <li>4</li>
                <li>5</li>
            </ul>
        </div>
        <div id="tab_body">
            <div class="dom" style="display: block;">
                <ul>
                    <li>1</li>
                    <li>1</li>
                    <li>1</li>
                    <li>1</li>
                </ul>
            </div>
            <div class="dom">
                <ul>
                    <li>2</li>
                    <li>2</li>
                    <li>2</li>
                    <li>2</li>
                </ul>
            </div>
            <div class="dom">
                <ul>
                    <li>3</li>
                    <li>3</li>
                    <li>3</li>
                    <li>3</li>
                </ul>
            </div>
            <div class="dom">
                <ul>
                    <li>4</li>
                    <li>4</li>
                    <li>4</li>
                    <li>4</li>
                </ul>
            </div>
            <div class="dom">
                <ul>
                    <li>5</li>
                    <li>5</li>
                    <li>5</li>
                    <li>5</li>
                </ul>
            </div>
        </div>
    </div>

css就不放了

js

window.onload = function(){
    var allLis = $('tab_header').getElementsByTagName('li');
    var allDoms = $('tab_body').getElementsByClassName('dom');
    console.log(allLis,allDoms);
    // 遍历拿到的allLis
    for(var i =0; i<allLis.length;i++){
        var li = allLis[i];
        li.index = i; 
        li.onmouseover = function(){
            // 排他思想 将所有的class清空
            for(var j = 0;j<allLis.length;j++){
                allLis[j].className = '';
                allDoms[j].style.display='none';
            }
           this.className = 'seclect';
           allDoms[this.index].style.display='block';
        }
    }
}
function $(id){
    return typeof id === "string" ? document.getElementById(id) : null;
}

这里面的 function $(id) 是我封装的一个dom id选择器,
在里面先拿到准备操作的事件源,遍历拿到的数组,onmouseover鼠标移入时,再次遍历一数组,将数组里所有的classname 变为空,以及display样式隐藏,在移入时,移入哪个,给哪个赋值即可。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值