layui中tab的添加拒绝重复

原创 2018年02月07日 17:13:59

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);
  });




 

layerui代码控制tab选项卡,添加,关闭

layui                                                 layui 后台布局             ...
  • huyanliang
  • huyanliang
  • 2017年09月13日 15:21
  • 3635

layui tab控件中载入外部html页面

目前,潜入外部网页的方式,主要有3种: iframe方式 ajax方式 ajax加载数据后,直接赋予 externalHtml.innerHTML 即可。...
  • djshichaoren
  • djshichaoren
  • 2017年10月23日 17:35
  • 1651

easyui 添加不重复的tab选项卡

$('#tt').tabs({ closable : true, tabPosition : 'left', headerWidth : 100 ...
  • xukang11111
  • xukang11111
  • 2016年04月08日 17:36
  • 768

layuicms 后台管理系统中,右侧子窗口的链接在tab选项卡中打开

博纵 $(".panel a").on("click",function(){ window.parent.addTab($(this)); });
  • k8080880
  • k8080880
  • 2017年09月13日 15:02
  • 1131

layui-选项卡

layui-选项卡
  • ajlgl
  • ajlgl
  • 2017年05月19日 09:09
  • 43146

Ztree树形结构结合tabs以及各种事件

Ztree 树形结构,与事件。异步刷新
  • qq_35826579
  • qq_35826579
  • 2017年12月26日 16:36
  • 103

layui问题汇总

1、动态添加tab,无法显示关闭按钮,或关闭按钮无效 在添加tab的代码处加入以下代码 //触发事件 var active = { tabAdd: function() { ...
  • wyccyw123456
  • wyccyw123456
  • 2016年11月29日 11:26
  • 8646

使用layui组件的小问题1.0,

今天使用layui搭建一个后台管理过程中,遇到了点小问题,很简单,但是想写下来,如果有一些初学的朋友要学可以看看。 1.使用预加载和layui.config配置全局的时候,方法和其他的差不多。 预...
  • Faded_u
  • Faded_u
  • 2017年04月18日 19:24
  • 1427

tab选项卡 ‘上一步‘ ‘下一步形式’

今天工作遇到个需求,就是在一个页面中用上一步,下一步实现页面内容的转换,这让我一下就想到了tab选项卡,两者很像,只不过用来用来转换内容的不再是上面的标签,而且“上一步”“下一步”这样的button。...
  • zcy_csdn123
  • zcy_csdn123
  • 2017年08月22日 19:00
  • 425

关于layui数据表格的分页操作的学习笔记。

-----初识layui,一个强大的前端框架。 在使用layui框架的时候需要引用layui相关文件。这里不做叙述直接传送门:layui官网 在官方文档中介绍了三种初始化渲染方式 ...
  • qq_16767917
  • qq_16767917
  • 2017年09月19日 10:58
  • 436
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:layui中tab的添加拒绝重复
举报原因:
原因补充:

(最多只允许输入30个字)