更新时间:2021-08-17 来源:黑马程序员 浏览量:
单击小标签右上角的按钮可D头删除标签页。其开发思路是,为“x”元素绑定单击事件,事件触发后,通过父元素1i获取索弓引值,然后用这个索引值将对应的li和section删除,并在删除后更新标签页的选中效电下面我们们就开始进行代码编写。
(1)在udeatNode()方法中获取所有的“x”元素,具体代码如下。
updateNode (){ ......(原有代码) this. Remove=this.main querySelectorAll('.icon-close'); }
(2) 在init()方法的for循环中,为每个“x”元素绑定单击事件。
for(vari=0; i<this.lis.length; i++) .....(原有代码) this . remove[i].onclick =function(e){ that romor hat. removeTab(this, e);
在上述代码中,第4行代码将触发事件的对象this和事件对象e传给removeTab0方法。
(3)编写removeTab0事件,实现标签页的删除,具体代码如下。
removeTab (el,e) { e. stopPropagation(); //阻止冒泡,防止触发li的click事件切换标签页 var index = 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)通过浏览器访问测试,观察删除标签页功能是否已经实现。
猜你喜欢: