DAY2

作者: 小可_34e0 | 来源:发表于2019-10-26 08:09 被阅读0次

    面向对象tab栏,完成增删改查
    HTML代码:

    <!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>Document</title>
    </head>
    <body>
        <h4>js面向对象 动态添加标签页</h4>
        <div class="tabsbox" id="tab">
             <!--tab标签-->
             <nav class="firstnav">
                <ul>
                    <li class="liactive"><span>测试1</span><span class="iconfont icon-gunbi"></span></li>
                    <li><span>测试2</span><span class="iconfont icon-gunbi"></span></li>
                    <li><span>测试3</span><span class="iconfont icon-gunbi"></span></li>
                </ul>
                <div class="tabadd">
                    <span>+</span>
                </div>
             </nav>
    
             <!--tab内容-->
             <div class="tabscon">
                <section class="conactive">测试1</section>
                <section>测试2</section>
                <section>测试3</section>
             </div>
        </div>
        <script src="tab.js"></script>
    </body>
    </html>
    

    JS代码:

    var that;
    class Tab{
        constructor(id){
            //获取元素
            that=this;
            this.main=document.querySelector(id);
            this.add=this.main.querySelector('.tabadd');
             //li的父元素
            this.ul=this.main.querySelector('.firstnav ul:first-child');
            //section父元素
            this.fsection=this.main.querySelector('.tabscon');
            this.init();
            
        }
        init(){
            this.updataNode();
            //init 初始化操作让相关的元素绑定事件
            this.add.onclick=this.addTab;
            for(var i=0;i<this.lis.length;i++){
                this.lis[i].index=i;
                this.lis[i].onclick=this.toggleTab;
                this.remove[i].onclick=this.removeTab;
                this.span[i].ondbclick=this.editTab;
                this.sections[i].ondbclick=this.editTab;
                }
            }
            //获取所有的li和section
        updataNode(){
            this.lis=this.main.querySelector('li');
            this.sections=this.main.querySelector('section');
            this.remove=this.main.querySelectorAll('.icon-guanbi');
            this.spans=this.main.querySelectorAll('.firstnav li span:first-child');
        }
    
        //1.切换功能
        toggleTab(){
            that.clearClass();
            this.className='liactive';
            that.sections[this.index].className='conactive';
        }
        //清除所有兄弟样式
        clearClass(){
            for(var i=0;i<this.lis.length;i++){
                this.lis[i].className='';
                this.sections[i].className='';
    
            }
        }
        //2.添加功能
        addTab(){
            that.clearClass();
            //(1)创建li元素和section元素
            var li='<li class='liactive'><span>新选项卡</span><span class='iconfont icon-guanbi'></span></li>'
            var section='<section class='conactive'>测试1</section>';
            //(2)把这两个元素追加到对应的父元素里面
            that.ul.insertAdjacentHTML('befo reend',li);
            that.fsection.insertAdjacentHTML('beforeend',section);
            that.init();
        }
        //3.删除功能
        removeTab(){
            e.stopPropagation();//阻止冒泡,防止触发li的切换点击事件
            var index=this.parentNode.index;
            //根据索引号删除对应的li和section
            that.lis[index].remove();
            that.section[index].remove();
            that.init();
            //当我们删除的不是选定状态的li的时候,原来的转中状态li保持不变
            if(document.querySelector('.liactive')) return;
            //当我们删除了选中状态的这个li的时候,让他的其哪一个li处于选定状态
            index--;
            //手动调用我们的点击事件,不需要鼠标触发
            that.lis[index]&&that.lis[index].click();
    
        }
        //4.修改功能
        editTab(){
            var str=this.innerHTML;
            //双击禁止选定文字
            window.getSelection?window.getSelection().removeAllRanges():document.selection.empty();
            //双击添加文本框
            this.innerHTML='<input type='text'/>';
            var input=this.children[0];
            input.value=str;
            input.select();//文本框里面的文字处于选定状态
            //当我们离开文本框的时候把文本框里面的内容给span
            input.onblur=function(){
                this.parentNode,innerHTML=this.value;
            };
            //按下回车也可以把文本框里面的值给span
            input.onkeyup=function(e){
                if(e.onkeyup==13){
                    //手动调用表单失去焦点事件 不需要鼠标离开操作
                    this.blur();
                }
            }
    
        }
    }
    new Tab('#tab');
    

    相关文章

      网友评论

          本文标题:DAY2

          本文链接:https://www.haomeiwen.com/subject/zekamctx.html