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_03(ExtJs Grid的简单使用)
Oct 02 Javascript
为jquery.ui.dialog 增加“自动记住关闭时的位置”的功能
Nov 24 Javascript
JQuery实现鼠标滑过显示导航下拉列表
Sep 12 Javascript
javascript事件委托的用法及其好处简析
Apr 04 Javascript
JavaScript操作 url 中 search 部分方法函数
Jun 15 Javascript
详解Angularjs 如何自定义Img的ng-load 事件
Feb 15 Javascript
详解jQuery中关于Ajax的几个常用的函数
Jul 17 jQuery
详解vue中使用protobuf踩坑记
May 07 Javascript
详解微信小程序图片地扯转base64解决方案
Aug 18 Javascript
解决Vue-Router升级导致的Uncaught (in promise)问题
Aug 07 Javascript
js实现飞机大战游戏
Aug 26 Javascript
Echarts如何重新渲染实例详解
May 30 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
Yii框架关联查询with用法分析
2014/12/02 PHP
php定时执行任务设置详解
2015/02/06 PHP
为你总结一些php系统类函数
2015/10/21 PHP
详解Yii2 定制表单输入字段的标签和样式
2017/01/04 PHP
php的PDO事务处理机制实例分析
2017/02/16 PHP
JQuery实现的在新窗口打开链接的方法小结
2010/04/22 Javascript
加载 Javascript 最佳实践
2011/10/30 Javascript
JavaScript全排列的六种算法 具体实现
2013/06/29 Javascript
jquery获取元素值的方法(常见的表单元素)
2013/11/15 Javascript
JS实现关键字搜索时的相关下拉字段效果
2014/08/05 Javascript
jq实现左侧显示图片右侧文字滑动切换效果
2015/08/04 Javascript
JS实现网页标题随机显示名人名言的方法
2015/11/03 Javascript
JavaScript前端开发之实现二进制读写操作
2015/11/04 Javascript
js阻止冒泡和默认事件(默认行为)详解
2016/10/20 Javascript
ES6新特性七:数组的扩充详解
2017/04/21 Javascript
Node.js+ES6+dropload.js实现移动端下拉加载实例
2017/06/01 Javascript
ES6正则表达式扩展笔记
2017/07/25 Javascript
使用Vue写一个datepicker的示例
2018/01/27 Javascript
JS简单判断是否在微信浏览器打开的方法示例
2019/01/08 Javascript
vue实现图书管理系统
2020/12/29 Vue.js
[01:54]胎教DOTA2 准妈妈玩家现身中国区预选赛
2016/06/26 DOTA
实现python版本的按任意键继续/退出
2016/09/26 Python
Python实现动态加载模块、类、函数的方法分析
2017/07/18 Python
浅谈numpy生成数组的零值问题
2018/11/12 Python
钉钉群自定义机器人消息Python封装的实例
2019/02/20 Python
Python实现Restful API的例子
2019/08/31 Python
使用Python将字符串转换为格式化的日期时间字符串
2019/09/01 Python
Python使用jpype模块调用jar包过程解析
2020/07/29 Python
法学专业本科生自荐信范文
2013/12/17 职场文书
市场部规章制度
2014/01/24 职场文书
危爆物品安全大检查大整治工作方案
2014/05/03 职场文书
优秀班组长事迹
2014/05/31 职场文书
社会稳定风险评估方案
2014/06/02 职场文书
2015年物流客服工作总结
2015/07/27 职场文书
2016年9月份红领巾广播稿
2015/12/21 职场文书
中国古风插画师排行榜:夏达第一,第三是阴阳师姑获鸟皮肤创作者
2022/03/18 国漫