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


Posted in Javascript onSeptember 04, 2019

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的添加拒绝重复的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript 键盘事件的组合使用实现代码
May 04 Javascript
javascript上传图片前预览图片兼容大多数浏览器
Oct 25 Javascript
jQuery的ready方法详解
Nov 27 Javascript
js如何改变文章的字体大小
Jan 08 Javascript
js弹出框、对话框、提示框、弹窗实现方法总结(推荐)
May 31 Javascript
让浏览器崩溃的12行JS代码(DoS攻击分析及防御)
Oct 10 Javascript
Vue.js常用指令汇总(v-if、v-for等)
Nov 03 Javascript
微信小程序实现传参数的几种方法示例
Jan 10 Javascript
Vue.js实现可配置的登录表单代码详解
Mar 29 Javascript
Vue + better-scroll 实现移动端字母索引导航功能
May 07 Javascript
vue-router权限控制(简单方式)
Oct 29 Javascript
如何手动实现es5中的bind方法详解
Dec 07 Javascript
Layui 导航默认展开和菜单栏选中高亮设置的方法
Sep 04 #Javascript
微信小程序官方动态自定义底部tabBar的例子
Sep 04 #Javascript
layerui代码控制tab选项卡,添加,关闭的实例
Sep 04 #Javascript
layui 表单标签的校验方法
Sep 04 #Javascript
解决layui 表单元素radio不显示渲染的问题
Sep 04 #Javascript
对layer弹出框中icon数字参数的说明介绍
Sep 04 #Javascript
Element 默认勾选表格 toggleRowSelection的实现
Sep 04 #Javascript
You might like
PHP模拟SQL Server的两个日期处理函数
2006/10/09 PHP
php is_file 判断给定文件名是否为一个正常的文件
2010/05/10 PHP
php curl模拟post请求小实例
2013/11/13 PHP
PHP中抽象类、接口的区别与选择分析
2016/03/29 PHP
使用PHPStorm+XDebug搭建单步调试环境
2017/11/19 PHP
PHP 命名空间和自动加载原理与用法实例分析
2020/04/29 PHP
js在IE与firefox的差异集锦
2014/11/11 Javascript
JS+CSS实现Div弹出窗口同时背景变暗的方法
2015/03/04 Javascript
jquery专业的导航菜单特效代码分享
2015/08/29 Javascript
利用HTML5的画布Canvas实现刮刮卡效果
2015/09/06 Javascript
jQuery+CSS3折叠卡片式下拉列表框实现效果
2015/11/02 Javascript
jQuery获取元素父节点的方法
2016/06/21 Javascript
jquery实用技巧之输入框提示语句
2016/07/28 Javascript
JS实现简单的二元方程计算器功能示例
2017/01/03 Javascript
原生js实现倒计时--2018
2017/02/21 Javascript
基于jstree使用AJAX请求获取数据形成树
2017/08/29 Javascript
Jquery实现无缝向上循环滚动列表的特效
2019/02/13 jQuery
Vue中watch、computed、updated三者的区别及用法
2020/07/27 Javascript
Python中处理unchecked未捕获异常实例
2015/01/17 Python
巧用python和libnmapd,提取Nmap扫描结果
2016/08/23 Python
OpenCV2.3.1+Python2.7.3+Numpy等的配置解析
2018/01/05 Python
Python中正反斜杠(‘/’和‘\’)的意义与用法
2019/08/12 Python
python反编译教程之2048小游戏实例
2021/03/03 Python
css3的transition效果和transfor效果示例介绍
2013/10/30 HTML / CSS
CSS3 按钮边框动画的实现
2020/11/12 HTML / CSS
英国电子专家:maplin
2019/09/04 全球购物
大四自我鉴定范文
2013/10/06 职场文书
合作协议书怎么写
2014/04/18 职场文书
学校文明单位申报材料
2014/05/06 职场文书
普通党员自我剖析材料
2014/10/07 职场文书
委托证明范本
2014/11/25 职场文书
2015年幼儿园保育员工作总结
2015/04/23 职场文书
2015年乡镇财政工作总结
2015/05/19 职场文书
2015年骨干教师工作总结
2015/05/26 职场文书
国王的演讲观后感
2015/06/03 职场文书
Go语言特点及基本数据类型使用详解
2022/03/21 Golang