最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:懂视网 责编:小采 时间:2020-11-27 21:51:20
文档

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

layui实现tab的添加拒绝重复的方法:layui中tab的添加:重复添加,没有自动跳转肯定让你烦了很久吧,我也是花了很久才解决的 前提是这样的:我点击不同按钮生成对应tab,而且再点击前已经有一个tab了(比如说:首页,个人需求而已) 我的思路是这样的:每添加一个tab用链表存储其id,通过
推荐度:
导读layui实现tab的添加拒绝重复的方法:layui中tab的添加:重复添加,没有自动跳转肯定让你烦了很久吧,我也是花了很久才解决的 前提是这样的:我点击不同按钮生成对应tab,而且再点击前已经有一个tab了(比如说:首页,个人需求而已) 我的思路是这样的:每添加一个tab用链表存储其id,通过

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

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

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

layui实现tab的添加拒绝重复的方法:layui中tab的添加:重复添加,没有自动跳转肯定让你烦了很久吧,我也是花了很久才解决的 前提是这样的:我点击不同按钮生成对应tab,而且再点击前已经有一个tab了(比如说:首页,个人需求而已) 我的思路是这样的:每添加一个tab用链表存储其id,通过
推荐度:
标签: 方法 tab la
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top