单击小标签右上角的按钮可D头删除标签页。其开发思路是,为“x”元素绑定单击事件,事件触发后,通过父元素1i获取索弓引值,然后用这个索引值将对应的li和section删除,并在删除后更新标签页的选中效果。
下面我们们就开始进行代码编写。
(1)在udeatNode()方法中获取所有的“x”元素,具体代码如下。
updateNode(){......(原有代码)this.Remove=this.mainquerySelectorAll('.icon-close');}
(2)在init()方法的for循环中,为每个“x”元素绑定单击事件。
for(vari=0;i<this.lis.length;i++).....(原有代码)this.remove[i].onclick=function(e){thatromorthat.removeTab(this,e);
在上述代码中,第4行代码将触发事件的对象this和事件对象e传给removeTab0方法。
(3)编写removeTab0事件,实现标签页的删除,具体代码如下。
removeTab(el,e){e.stopPropagation();//阻止冒泡,防止触发li的click事件切换标签页varindex=el.parentNode.index;//获取父元素的索引this.lis[index].remove();this.sections[index].remove();this.init();}
在上述代码中,由于“x”元素是小标签li元素的子元素,当“x”被单击时,会发生冒泡,导致li的单击事件也触发,所以需要通过第2行代码阻止事件冒泡。
(4)在删除了li和section元素以后,还需要更新标签页的选中状态。有两种情况,一种是删除了当前正在显示的标签页,删除以后,就把上一个标签页设为选中状态;
另一种情况是删除了一个没有打开的标签页,这个时候原来的选中状态应该保持不变。
为了区分这两种状态,可以在删除了标签页以后,判断当前是否存在已被打开的标签页,如果不存在,说明删除的是已被打开的标签页,就把上一个标签页设为选中状态即可,具体代码如下:
removeTab(el,e){....(原有代码)if(!this.main.querySelector('.liactive')){this.lis[index-1]&&this.lis[index-1].click();}}
在上述代码中,第3行代码用来判断main元素中是否有已被打开的标签页,如果没有,则执行if中的代码。
第4行代码用来将上一个标签页设为选中状态,在设置前,先判断是否存在上一个标签页,以避免全部关闭的时候程序出错。
(5)通过浏览器访问测试,观察删除标签页功能是否已经实现。