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 相关文章推荐
深入理解JSON数据源格式
Jan 10 Javascript
jQuery学习笔记之jQuery.extend(),jQuery.fn.extend()分析
Jun 09 Javascript
jQuery超简单选项卡完整实例
Sep 26 Javascript
BootStrap table使用方法分析
Nov 08 Javascript
jQuery Easyui datagrid连续发送两次请求问题
Dec 13 Javascript
jquery.zclip轻量级复制失效问题
Jan 08 Javascript
js中setTimeout的妙用--防止循环超时
Mar 06 Javascript
元素全屏的设置与监听实例
Nov 28 Javascript
JavaScript中为事件指定处理程序的五种方式分析
Jul 27 Javascript
vue-quill-editor富文本编辑器简单使用方法
Sep 21 Javascript
JavaScript如何获取一个元素的样式信息
Jul 29 Javascript
浅谈Vue为什么不能检测数组变动
Oct 14 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
Smarty模板引擎缓存机制详解
2016/05/23 PHP
验证token、回复图文\文本、推送消息的实用微信类php代码
2016/06/28 PHP
PHP实现递归的三种方法
2020/07/04 PHP
PHP 99乘法表的几种实现代码
2020/10/13 PHP
PHP7 标准库修改
2021/03/09 PHP
不错的asp中显示新闻的功能
2006/10/13 Javascript
js 弹出框 替代浏览器的弹出框
2010/10/29 Javascript
jquery 操作日期、星期、元素的追加的实现代码
2012/02/07 Javascript
javascript向后台传送相同属性的参数即数组参数
2014/02/17 Javascript
使用 TypeScript 重新编写的 JavaScript 坦克大战游戏代码
2015/04/07 Javascript
使用jQuery监听DOM元素大小变化
2016/02/24 Javascript
JavaScript队列函数和异步执行详解
2017/06/19 Javascript
Vue中正确使用jQuery的方法
2017/10/30 jQuery
基于Vue制作组织架构树组件
2017/12/06 Javascript
vue中各选项及钩子函数执行顺序详解
2018/08/25 Javascript
angularjs实现对表单输入改变的监控(ng-change和watch两种方式)
2018/08/29 Javascript
vue-cli配置flexible过程详解
2019/07/04 Javascript
mpvue实现小程序签到金币掉落动画(api实现)
2019/10/17 Javascript
JavaScript实现随机点名程序
2020/03/25 Javascript
angular中的post请求处理示例详解
2020/06/30 Javascript
vue+elementUI中表格高亮或字体颜色改变操作
2020/11/02 Javascript
用Python实现命令行闹钟脚本实例
2016/09/05 Python
python抖音表白程序源代码
2019/04/07 Python
Python pandas实现excel工作表合并功能详解
2019/08/29 Python
Python 迭代,for...in遍历,迭代原理与应用示例
2019/10/12 Python
使用Python求解带约束的最优化问题详解
2020/02/11 Python
python如何快速拼接字符串
2020/10/28 Python
HTML5 与 XHTML2
2008/10/17 HTML / CSS
HTML5 通过Vedio标签实现视频循环播放的示例代码
2020/08/05 HTML / CSS
《飞向蓝天的恐龙》教学反思
2014/04/09 职场文书
诚信承诺书
2015/01/19 职场文书
蓬莱阁导游词
2015/02/04 职场文书
政府会议通知范文
2015/04/15 职场文书
2016入党积极分子考察评语
2015/12/01 职场文书
读后感怎么写?书写读后感的基本技巧!
2019/12/10 职场文书
linux目录管理方法介绍
2022/06/01 Servers