js批量添加事件监听,用于处理tab标签选中的一个示例

之前每次网上找的好看的控件都不知道如何切换标签,因为通常提供的都是html,需要自己写js,无从下手,本次通过自己的理解学会了一个tab页面的激活与取消(简单的方法,以前的方法很笨拙),通过js遍历添加事件监听的方式,无论你有多少个tab页面都无需修改js了,自动适应。

例子是使用了SUI的一个工具栏,提供了3个按钮,自己给了3个tab content与之一一对应,通过点击工具栏的按钮实现工具栏指定按钮激活与tab content的激活。

html代码如下:

  <!-- 工具栏 -->
            <nav class="bar bar-tab" id="tool_bar_id">
                <a class="tab-item external active" href="#" id="tab-item-1" name ="tab1">
                    <span class="icon icon-home"></span>
                    <span class="tab-label">实时数据</span>
                </a>
                <a class="tab-item external" href="#" id="tab-item-2" name ="tab2">
                    <span class="icon icon-star"></span>
                    <span class="tab-label">历史数据</span>
                </a>
                <a class="tab-item external" href="#" id="tab-item-3" name ="tab3">
                    <span class="icon icon-settings"></span>
                    <span class="tab-label">图片列表</span>
                </a>
            </nav>

            <!-- 这里是页面内容区 -->
            <div class="content-block">
                <div class="tabs" id="tab_content_id">
                  <div id="tab1" class="tab active">
                    <div class="content-block">
                      <p>This is tab 1 content</p>
                    </div>
                  </div>
                  <div id="tab2" class="tab">
                    <div class="content-block">
                      <p>This is tab 2 content</p>
                    </div>
                  </div>
                  <div id="tab3" class="tab">
                    <div class="content-block">
                      <p>This is tab 3 content</p>
                    </div>
                  </div>
                </div>
              </div>

js如下(原理通过注释写的比较清楚):

 var obj = document.getElementById('tool_bar_id');       //获取工具栏整个对象
                var tab_item = obj.querySelectorAll('.tab-item');       //选取含tab-item样式的对象集合
                var TabArray = Array.prototype.slice.call(tab_item,0);  //获取tab标签集合

                TabArray.forEach(function (e1) {                        //遍历
                    //console.log(e1.className);
                    e1.onclick = function(event)                        //为当前对象添加点击事件-为工具栏图标添加点击事件
                    {
                        var obj = document.getElementById('tool_bar_id'); //首先获取工具栏整个对象
                        var tab_item = obj.querySelectorAll('.tab-item');   //选取含tab-item样式的对象
                        var tabs_obj = document.getElementById('tab_content_id'); //获取tab页面content对象
                        var tab_content = tabs_obj.querySelectorAll('.tab'); //选取含tab样式的对象集合
                        for (var i = 0; i < tab_item.length; i++)           //循环处理所有按钮与content(按钮与content要一一对应)
                        {
                            if (event.currentTarget.id == tab_item[i].id)       //找到了当前选择的按钮id,则激活按钮与对应的content
                            {
                                tab_content[i].classList.add('active'); //激活content
                                tab_item[i].classList.add('active');    //激活按钮
                            }
                            else
                            {
                                tab_content[i].classList.remove('active');//移除激活状态
                                tab_item[i].classList.remove('active');//移除激活状态
                            }
                        }
                    }
                });

最终效果如下:

点击按钮1

点击按钮2

点击按钮3

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cp1300

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值