kayui进行添加_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

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

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

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:""

,id:id

});

arry.append(id);

}

//切换tab

element.tabChange('tab',id);

}

//监听tab删除

element.on('tabDelete', function(data){

arry.removeAt(data.index);

});

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

本站文章为3672js教程网友分享投稿,版权归原作者,欢迎任何形式的转载,但请务必注明出处。同时文章内容如有侵犯了您的权益,请联系我们处理。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值