layui實現(xiàn)tab的添加拒絕重復的方法
layui中tab的添加:重復添加,沒有自動跳轉肯定讓你煩了很久吧,我也是花了很久才解決的
前提是這樣的:我點擊不同按鈕生成對應tab,而且再點擊前已經(jīng)有一個tab了(比如說:‘首頁‘,個人需求而已)
我的思路是這樣的:每添加一個tab用鏈表存儲其id,通過id判斷是否存在,并確定是添加tab還是跳轉到指定tab。
刪除時,監(jiān)聽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;
//在尾部添加節(jié)點
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é)點
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é)點
this.removeAt=function(ii){
node1=this.head; //要刪除節(jié)點的前一個節(jié)點
for(i=0;i<ii;i++){
if(node1.next!=null){
node1=node1.next;
}else{
break;
}
}
node2=node1.next; //要刪除的節(jié)點
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;
}
//查找某個節(jié)點的值
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:
/**
* 點擊節(jié)點添加tab
* title:選項卡標題,id:選項卡的id,url:選項卡所顯示的內(nèi)容《用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);
}
//監(jiān)聽tab刪除
element.on('tabDelete', function(data){
arry.removeAt(data.index);
});
以上這篇layui實現(xiàn)tab的添加拒絕重復的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
JavaScript實現(xiàn)圖片懶加載的三種方案詳解
圖片懶加載,當圖片出現(xiàn)在可視區(qū)域再進行加載,提升用戶的體驗,這篇文章主要為大家整理了三個常用的圖片懶加載實現(xiàn)方法,希望對大家有所幫助2023-12-12
微信小程序實現(xiàn)圖片上傳功能實例(前端+PHP后端)
這篇文章主要給大家介紹了關于微信小程序實現(xiàn)圖片上傳功能的相關內(nèi)容,文中詳細介紹了前端+PHP后端的示例代碼,對大家的理解和學習具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2018-01-01

