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 相关文章推荐
Prototype Hash对象 学习
Jul 19 Javascript
JavaScript实现的石头剪刀布游戏源码分享
Aug 22 Javascript
node+express+ejs制作简单页面上手指南
Nov 26 Javascript
jQuery实现将页面上HTML标签换成另外标签的方法
Jun 09 Javascript
jquery实现左右滑动菜单效果代码
Aug 27 Javascript
jQuery EasyUI tree 使用拖拽时遇到的错误小结
Oct 10 Javascript
jQuery中值得注意的trigger方法浅析
Dec 12 Javascript
使用html+js+css 实现页面轮播图效果(实例讲解)
Sep 21 Javascript
Vue2仿淘宝实现省市区三级联动
Apr 15 Javascript
vue中进入详情页记住滚动位置的方法(keep-alive)
Sep 21 Javascript
使用electron实现百度网盘悬浮窗口功能的示例代码
Oct 24 Javascript
微信小程序错误this.setData报错及解决过程
Sep 18 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函数nl2br()与自定义函数nl2p()换行用法分析
2016/04/02 PHP
Javascript实现CheckBox的全选与取消全选的代码
2010/07/20 Javascript
js模拟点击以提交表单为例兼容主流浏览器
2013/11/29 Javascript
js如何设置在iframe框架中指定div不显示
2013/12/04 Javascript
自己实现ajax封装示例分享
2014/04/01 Javascript
一个html5播放视频的video控件只支持android的默认格式mp4和3gp
2014/05/08 Javascript
简单谈谈jQuery(function(){})与(function(){})(jQuery)
2014/12/19 Javascript
EsLint入门学习教程
2017/02/17 Javascript
js实现常见的工具条效果
2017/03/02 Javascript
浅析vue深复制
2018/01/29 Javascript
vue-music 使用better-scroll遇到轮播图不能自动轮播问题
2018/12/03 Javascript
JS+CSS+HTML实现“代码雨”类似黑客帝国文字下落效果
2020/03/17 Javascript
运行django项目指定IP和端口的方法
2018/05/14 Python
python 定时任务去检测服务器端口是否通的实例
2019/01/26 Python
python 发送和接收ActiveMQ消息的实例
2019/01/30 Python
python安装pil库方法及代码
2019/06/25 Python
PyCharm搭建Spark开发环境的实现步骤
2019/09/05 Python
python 使用cx-freeze打包程序的实现
2020/03/14 Python
matplotlib 对坐标的控制,加图例注释的操作
2020/04/17 Python
Python如何把Spark数据写入ElasticSearch
2020/04/18 Python
python继承threading.Thread实现有返回值的子类实例
2020/05/02 Python
pytorch加载自己的图像数据集实例
2020/07/07 Python
北美领先的牛仔品牌:Buffalo David Bitton
2017/05/22 全球购物
英国领先的运动营养品牌:Protein Dynamix
2018/01/02 全球购物
Coltorti Boutique官网:来自意大利的设计师品牌买手店
2018/11/09 全球购物
餐厅经理岗位职责和岗位目标
2014/02/13 职场文书
出纳员岗位职责风险
2014/03/06 职场文书
校长寄语大全
2014/04/09 职场文书
教师党员个人自我剖析材料
2014/09/29 职场文书
导游词欢迎词
2015/02/02 职场文书
2015年教学工作总结
2015/04/02 职场文书
蜗居观后感
2015/06/11 职场文书
社会心理学学习心得体会
2016/01/22 职场文书
Python爬取科目四考试题库的方法实现
2021/03/30 Python
CSS 使用 resize 实现图片拖拽切换预览功能(强大功能)
2021/08/23 HTML / CSS
MySQL远程无法连接的一些常见原因总结
2022/09/23 MySQL