layui实现tab的添加拒绝重复的方法
作者:雨中飞蛾
今天小编就为大家分享一篇layui实现tab的添加拒绝重复的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
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的添加拒绝重复的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。