首页技术文章正文

JavaScript面向对象怎样删除标签页?

更新时间:2021-08-17 来源:黑马程序员 浏览量:

IT培训班

单击小标签右上角的按钮可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行代码阻止事件冒泡。

1629171917747_删除标签页.jpg


(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)通过浏览器访问测试,观察删除标签页功能是否已经实现。






猜你喜欢:

javascript的垃圾回收机制指的是什么?

3种JavaScript代码书写位置和注意事项 ?

HTML网页格式化:标题标签、段落标签和水平标签

怎样对网页标签进行精准定位?【web前端】

黑马程序员web前端培训课程

分享到:
在线咨询 我要报名
和我们在线交谈!