亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

layui實(shí)現(xiàn)tab的添加拒絕重復(fù)的方法

 更新時(shí)間:2019年09月04日 10:32:09   作者:雨中飛蛾  
今天小編就為大家分享一篇layui實(shí)現(xiàn)tab的添加拒絕重復(fù)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

layui中tab的添加:重復(fù)添加,沒(méi)有自動(dòng)跳轉(zhuǎn)肯定讓你煩了很久吧,我也是花了很久才解決的

前提是這樣的:我點(diǎn)擊不同按鈕生成對(duì)應(yīng)tab,而且再點(diǎn)擊前已經(jīng)有一個(gè)tab了(比如說(shuō):‘首頁(yè)‘,個(gè)人需求而已)

我的思路是這樣的:每添加一個(gè)tab用鏈表存儲(chǔ)其id,通過(guò)id判斷是否存在,并確定是添加tab還是跳轉(zhuǎn)到指定tab。

刪除時(shí),監(jiān)聽(tīng)tab的刪除,然后從鏈表里刪除對(duì)應(yīng)id。但是在element.on('tabDelete',function(data){});中得不到你刪除tab的id。有幸的是,能得到下標(biāo):data.index。我用其表示鏈表中的‘第幾個(gè)元素',因?yàn)閐ata.index的值是“流動(dòng)”的,以這種方式表示(考慮到操作的方式)很適合用鏈表來(lái)形容(建議你自己console.log(data.index)來(lái)看看)。

好了,上代碼

list.js:我把它寫(xiě)在了公共類(lèi)里,你按照你自己的需求來(lái)

function Node(v){
  this.value=v;
  this.next=null;
 }
function ArrayList(){
	 this.head=new Node(null);
	  this.tail = this.head;
	  //在尾部添加節(jié)點(diǎn)
	  this.append=function(v){
	   node = new Node(v);
	   this.tail.next=node;
	   this.tail=node;
	  }
	  //在指定位置插入
	  this.insertAt=function(ii,v){
	   node = new Node(v);
	   //找到位置的節(jié)點(diǎn)
	   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;
	  }
	  //刪除指定節(jié)點(diǎn)
	  this.removeAt=function(ii){
	   node1=this.head; //要?jiǎng)h除節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)
	   for(i=0;i<ii;i++){
	    if(node1.next!=null){
	     node1=node1.next;
	    }else{
	     break;
	    }
	   }
	   node2=node1.next; //要?jiǎng)h除的節(jié)點(diǎn)
	   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;
	  }
	  //查找某個(gè)節(jié)點(diǎn)的值
	  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:

 /**
  * 點(diǎn)擊節(jié)點(diǎn)添加tab
  * title:選項(xiàng)卡標(biāo)題,id:選項(xiàng)卡的id,url:選項(xiàng)卡所顯示的內(nèi)容《用ifream》
  */
 var arry = new ArrayList();
 arry.append("xtsy");//這就是我的首頁(yè),你如果不需要的話,刪除即可
 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);
 }
//監(jiān)聽(tīng)tab刪除
 element.on('tabDelete', function(data){
  arry.removeAt(data.index);
 });

以上這篇layui實(shí)現(xiàn)tab的添加拒絕重復(fù)的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論