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:我把它写在了公共类里,你按照你自己的需求来
functionNode(v){
this.value=v;
this.next=null;
}
functionArrayList(){
this.head=newNode(null);
this.tail=this.head;
//在尾部添加节点
this.append=function(v){
node=newNode(v);
this.tail.next=node;
this.tail=node;
}
//在指定位置插入
this.insertAt=function(ii,v){
node=newNode(v);
//找到位置的节点
tempNode=this.head;
for(i=0;i
js:
/**
*点击节点添加tab
*title:选项卡标题,id:选项卡的id,url:选项卡所显示的内容《用ifream》
*/
vararry=newArrayList();
arry.append("xtsy");//这就是我的首页,你如果不需要的话,删除即可
functiontabAdd(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的添加拒绝重复的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。