首页 > 编程 > JavaScript > 正文

layui实现tab的添加拒绝重复的方法

2019-11-19 10:53:21
字体:
来源:转载
供稿:网友

layui中tab的添加:重复添加,没有自动跳转肯定让你烦了很久吧,我也是花了很久才解决的

前提是这样的:我点击不同按钮生成对应tab,而且再点击前已经有一个tab了(比如说:‘首页‘,个人需求而已)

我的思路是这样的:每添加一个tab用链表存储其id,通过id判断是否存在,并确定是添加tab还是跳转到指定tab。

删除时,监听tab的删除,然后从链表里删除对应id。但是在element.on('tabDelete',function(data){});中得不到你删除tab的id。有幸的是,能得到下标:data.index。我用其表示链表中的‘第几个元素',因为data.index的值是“流动”的,以这种方式表示(考虑到操作的方式)很适合用链表来形容(建议你自己console.log(data.index)来看看)。

好了,上代码

list.js:我把它写在了公共类里,你按照你自己的需求来

function Node(v){  this.value=v;  this.next=null; }function ArrayList(){	 this.head=new Node(null);	  this.tail = this.head;	  //在尾部添加节点	  this.append=function(v){	   node = new Node(v);	   this.tail.next=node;	   this.tail=node;	  }	  //在指定位置插入	  this.insertAt=function(ii,v){	   node = new Node(v);	   //找到位置的节点	   tempNode=this.head;	   for(i=0;i<ii;i++){	    if(tempNode.next!=null){	     tempNode=tempNode.next;	    }else{	     break;	    }	   }	   node.next=tempNode.next;	   tempNode.next = node;	  }	  //删除指定节点	  this.removeAt=function(ii){	   node1=this.head; //要删除节点的前一个节点	   for(i=0;i<ii;i++){	    if(node1.next!=null){	     node1=node1.next;	    }else{	     break;	    }	   }	   node2=node1.next; //要删除的节点	   if(node2!=null){	    node1.next = node2.next;	    if(node2.next==null){	      this.tail=node1;	     }	   }	  }	  //查找值	  this.find=function(v){	  	 var nodefin=this.head;	  	  while(nodefin.value!=v){	  	  	if(nodefin.next!=null){	  	      nodefin=nodefin.next;	  	  	}else{break;}	  	  }	  	  return nodefin;	  }	  //查找某个节点的值	  this.findv=function(ii){	  	var nodefv = this.head;	  	for(var i =0;i<ii;i++){	  		if(nodefv.next!=null){	  			nodefv=nodefv.next;	  		}	  	}	  	return nodefv;	  }	  //显示连表中的值	  this.show=function()	  {	  	var Node=this.head;	  	while(Node!=null)	  		{	  		 console.log(Node.value);	  		 Node=Node.next;	  		}	  }}

js:

 /**  * 点击节点添加tab  * title:选项卡标题,id:选项卡的id,url:选项卡所显示的内容《用ifream》  */ var arry = new ArrayList(); arry.append("xtsy");//这就是我的首页,你如果不需要的话,删除即可 function tabAdd(title,id,url) {  //判断tab是否存在  if(arry.find(id).value!=id){   element.tabAdd('tab', {     title: title //用于演示     ,content:"<iframe src='"+ url     + "' frameborder='0' style='width:100%;height:470px;'></iframe>"     ,id:id    });   arry.append(id);  }   //切换tab element.tabChange('tab',id); }//监听tab删除 element.on('tabDelete', function(data){  arry.removeAt(data.index); });

以上这篇layui实现tab的添加拒绝重复的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表