2017-12-01 24 views
0

以下は、4つのタブを含むJSのフィドルです。タブをクリックすると、タブの内容が変更されます。私はタブをクリックしないでタブを切り替える方法

JS Fiddle

$(document).ready(function() { 
    $(".tabs-menu a").click(function(event) { 
     event.preventDefault(); 
     $(this).parent().addClass("current"); 
     $(this).parent().siblings().removeClass("current"); 
     var tab = $(this).attr("href"); 
     $(".tab-content").not(tab).css("display", "none"); 
     $(tab).fadeIn(); 
    }); 
}); 

HTMLコード

<div id="tabs-container"> 
    <ul class="tabs-menu"> 
     <li class="current"><a href="#tab-1">Tab 1</a></li> 
     <li><a href="#tab-2">Tab 2</a></li> 
     <li><a href="#tab-3">Tab 3</a></li> 
     <li><a href="#tab-4">Tab 4</a></li> 
    </ul> 
    <div class="tab"> 
     <div id="tab-1" class="tab-content"> 
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam sit amet purus urna. Proin dictum fringilla enim, sit amet suscipit dolor dictum in. Maecenas porttitor, est et malesuada congue, ligula elit fermentum massa, sit amet porta odio est at velit. Sed nec turpis neque. Fusce at mi felis, sed interdum tortor. Nullam pretium, est at congue mattis, nibh eros pharetra lectus, nec posuere libero dui consectetur arcu. Quisque convallis facilisis fermentum. Nam tincidunt, diam nec dictum mattis, nunc dolor ultrices ipsum, in mattis justo turpis nec ligula. Curabitur a ante mauris. Integer placerat imperdiet diam, facilisis pretium elit mollis pretium. Sed lobortis, eros non egestas suscipit, dui dui euismod enim, ac ultricies arcu risus at tellus. Donec imperdiet congue ligula, quis vulputate mauris ultrices non. Aliquam rhoncus, arcu a bibendum congue, augue risus tincidunt massa, vel vehicula diam dolor eget felis.</p> 
     </div> 
     <div id="tab-2" class="tab-content"> 
      <p>Donec semper dictum sem, quis pretium sem malesuada non. Proin venenatis orci vel nisl porta sollicitudin. Pellentesque sit amet massa et orci malesuada facilisis vel vel lectus. Etiam tristique volutpat auctor. Morbi nec massa eget sem ultricies fermentum id ut ligula. Praesent aliquet adipiscing dictum. Suspendisse dignissim dui tortor. Integer faucibus interdum justo, mattis commodo elit tempor id. Quisque ut orci orci, sit amet mattis nulla. Suspendisse quam diam, feugiat at ullamcorper eget, sagittis sed eros. Proin tortor tellus, pulvinar at imperdiet in, egestas sed nisl. Aenean tempor neque ut felis dignissim ac congue felis viverra. </p> 

     </div> 
     <div id="tab-3" class="tab-content"> 
      <p>Duis egestas fermentum ipsum et commodo. Proin bibendum consectetur elit, hendrerit porta mi dictum eu. Vestibulum adipiscing euismod laoreet. Vivamus lobortis tortor a odio consectetur pulvinar. Proin blandit ornare eros dictum fermentum. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Curabitur laoreet, ante aliquet molestie laoreet, lectus odio fringilla purus, id porttitor erat velit vitae mi. Nullam posuere nunc ut justo sollicitudin interdum. Donec suscipit eros nec leo condimentum fermentum. Nunc quis libero massa. Integer tempus laoreet lectus id interdum. Integer facilisis egestas dui at convallis. Praesent elementum nisl et erat iaculis a blandit ligula mollis. Vestibulum vitae risus dui, nec sagittis arcu. Nullam tortor enim, placerat quis eleifend in, viverra ac lacus. Ut aliquam sapien ut metus hendrerit auctor dapibus justo porta. </p> 
     </div> 
     <div id="tab-4" class="tab-content"> 
      <p>Proin sollicitudin tincidunt quam, in egestas dui tincidunt non. Maecenas tempus condimentum mi, sed convallis tortor iaculis eu. Cras dui dui, tempor quis tempor vitae, ullamcorper in justo. Integer et lorem diam. Quisque consequat lectus eget urna molestie pharetra. Cras risus lectus, lobortis sit amet imperdiet sit amet, eleifend a erat. Suspendisse vel luctus lectus. Sed ac arcu nisi, sit amet ornare tellus. Pellentesque nec augue a nibh pharetra scelerisque quis sit amet felis. Nullam at enim at lacus pretium iaculis sit amet vel nunc. Praesent sapien felis, tincidunt vitae blandit ut, mattis at diam. Suspendisse ac sapien eget eros venenatis tempor quis id odio. Donec lacus leo, tincidunt eget molestie at, pharetra cursus odio. </p> 
     </div> 
    </div> 
</div><br/> 
<input type='submit' value='SET Tab 1 Active '/><br/><br/> 
<input type='submit' value='SET Tab 2 Active '/><br/><br/> 
<input type='submit' value='SET Tab 3 Active '/><br/><br/> 
<input type='submit' value='SET Tab 4 Active '/><br/><br/> 

ボタンまたは任意のイベントをクリックせずにのみ、CSS /スタイルを使用して、タブを交換する必要がある "タブメニュー" に適用さ 外部ボタンからタブを変更するにはどうすればいいですか?

は、上記

var SimpleTabs = function (elem) { 
    //get tab objects and store as pane + tab 
    var activeTabObject; 

    var TabObject = function() { 

     var self = this; 
     this.tab; //element 
     this.pane; //element 
     this.setClick = function() { 
      $(self.tab).click(function() { 
       self.showThisTab(); 
      }); 
     }; 

     this.showThisTab = function() { 
      if (self !== activeTabObject) { 

       //change the tab page and update the active tab 
       $(activeTabObject.pane).removeClass('active-page'); 
       $(activeTabObject.tab).removeClass('active'); 
       $(self.pane).addClass('active-page'); 
       $(self.tab).addClass('active'); 
       activeTabObject = self; 
      } 
     }; 

    }; 

    $.each(elem.children(), function (id,val){ 
     var tab = new TabObject(); 
     tab.tab = val; 
     var classString = $(val).attr('class'); 
     var className = classString.split(' ')[0]; 
     tab.pane = $('#' + className); 
     tab.setClick(); 
     if (classString.indexOf('active') > -1) { 
      activeTabObject = tab; 
     } 
    }); 

}; 

をJqueryUsedタブスイッチを扱うjqueryの抜粋です。

答えて

0
$(function() { 
$('.tabs-menu a').mouseover(function(){ 
    event.preventDefault(); 
    $(this).parent().addClass("current"); 
    $(this).parent().siblings().removeClass("current"); 
    var tab = $(this).attr("href"); 
    $(".tab-content").not(tab).css("display", "none"); 
    $(tab).fadeIn(); 

    }); 
}); 
+0

私は一番下にあるボタンから、これを必要とします。 –

2

コードを少し移動しましたが、読みやすくするためです。

$(document).ready(function() { 
 
    var $tabsMenu = $('.tabs-menu'); 
 
    var tabsMenuLength = $tabsMenu.children().length; 
 
    $tabsMenu.find("a").click(function(event) { 
 
    event.preventDefault(); 
 
    setCurrentTab(this); 
 
    }); 
 

 
    $('#tab-switch').click(function(e) { 
 
    var nextTabId = ($tabsMenu.find('.current').index() + 1) % tabsMenuLength; 
 
    setCurrentTab($tabsMenu.children()[nextTabId].childNodes[0]) 
 
    }); 
 
    
 
    // set initial tab as tab 3 
 
    setCurrentTab($tabsMenu.children()[2].childNodes[0]) 
 
}); 
 

 
function setCurrentTab(tabEl) { 
 
    $(tabEl).parent().addClass("current"); 
 
    $(tabEl).parent().siblings().removeClass("current"); 
 
    var tab = $(tabEl).attr("href"); 
 
    $(".tab-content").not(tab).css("display", "none"); 
 
    $(tab).fadeIn(); 
 
}
body { 
 
    padding: 20px; 
 
    font-family: Arial, Helvetica, sans-serif; 
 
    line-height: 1.5; 
 
    font-size: 14px; 
 
} 
 

 
.tabs-menu { 
 
    height: 30px; 
 
    float: left; 
 
    clear: both; 
 
} 
 

 
.tabs-menu li { 
 
    height: 30px; 
 
    line-height: 30px; 
 
    float: left; 
 
    margin-right: 10px; 
 
    background-color: #ccc; 
 
    border-top: 1px solid #d4d4d1; 
 
    border-right: 1px solid #d4d4d1; 
 
    border-left: 1px solid #d4d4d1; 
 
} 
 

 
.tabs-menu li.current { 
 
    position: relative; 
 
    background-color: #fff; 
 
    border-bottom: 1px solid #fff; 
 
    z-index: 5; 
 
} 
 

 
.tabs-menu li a { 
 
    padding: 10px; 
 
    text-transform: uppercase; 
 
    color: #fff; 
 
    text-decoration: none; 
 
} 
 

 
.tabs-menu .current a { 
 
    color: #2e7da3; 
 
} 
 

 
.tab { 
 
    border: 1px solid #d4d4d1; 
 
    background-color: #fff; 
 
    float: left; 
 
    margin-bottom: 20px; 
 
    width: auto; 
 
} 
 

 
.tab-content { 
 
    width: 660px; 
 
    padding: 20px; 
 
    display: none; 
 
} 
 

 
#tab-1 { 
 
    display: block; 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<div id="tabs-container"> 
 
    <ul class="tabs-menu"> 
 
    <li class="current"><a href="#tab-1">Tab 1</a></li> 
 
    <li><a href="#tab-2">Tab 2</a></li> 
 
    <li><a href="#tab-3">Tab 3</a></li> 
 
    <li><a href="#tab-4">Tab 4</a></li> 
 
    </ul> 
 
    <div class="tab"> 
 
    <div id="tab-1" class="tab-content"> 
 
     <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam sit amet purus urna. Proin dictum fringilla enim, sit amet suscipit dolor dictum in. Maecenas porttitor, est et malesuada congue, ligula elit fermentum massa, sit amet porta odio est 
 
     at velit. Sed nec turpis neque. Fusce at mi felis, sed interdum tortor. Nullam pretium, est at congue mattis, nibh eros pharetra lectus, nec posuere libero dui consectetur arcu. Quisque convallis facilisis fermentum. Nam tincidunt, diam nec dictum 
 
     mattis, nunc dolor ultrices ipsum, in mattis justo turpis nec ligula. Curabitur a ante mauris. Integer placerat imperdiet diam, facilisis pretium elit mollis pretium. Sed lobortis, eros non egestas suscipit, dui dui euismod enim, ac ultricies 
 
     arcu risus at tellus. Donec imperdiet congue ligula, quis vulputate mauris ultrices non. Aliquam rhoncus, arcu a bibendum congue, augue risus tincidunt massa, vel vehicula diam dolor eget felis.</p> 
 
    </div> 
 
    <div id="tab-2" class="tab-content"> 
 
     <p>Donec semper dictum sem, quis pretium sem malesuada non. Proin venenatis orci vel nisl porta sollicitudin. Pellentesque sit amet massa et orci malesuada facilisis vel vel lectus. Etiam tristique volutpat auctor. Morbi nec massa eget sem ultricies 
 
     fermentum id ut ligula. Praesent aliquet adipiscing dictum. Suspendisse dignissim dui tortor. Integer faucibus interdum justo, mattis commodo elit tempor id. Quisque ut orci orci, sit amet mattis nulla. Suspendisse quam diam, feugiat at ullamcorper 
 
     eget, sagittis sed eros. Proin tortor tellus, pulvinar at imperdiet in, egestas sed nisl. Aenean tempor neque ut felis dignissim ac congue felis viverra. </p> 
 

 
    </div> 
 
    <div id="tab-3" class="tab-content"> 
 
     <p>Duis egestas fermentum ipsum et commodo. Proin bibendum consectetur elit, hendrerit porta mi dictum eu. Vestibulum adipiscing euismod laoreet. Vivamus lobortis tortor a odio consectetur pulvinar. Proin blandit ornare eros dictum fermentum. Class 
 
     aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Curabitur laoreet, ante aliquet molestie laoreet, lectus odio fringilla purus, id porttitor erat velit vitae mi. Nullam posuere nunc ut justo sollicitudin interdum. 
 
     Donec suscipit eros nec leo condimentum fermentum. Nunc quis libero massa. Integer tempus laoreet lectus id interdum. Integer facilisis egestas dui at convallis. Praesent elementum nisl et erat iaculis a blandit ligula mollis. Vestibulum vitae 
 
     risus dui, nec sagittis arcu. Nullam tortor enim, placerat quis eleifend in, viverra ac lacus. Ut aliquam sapien ut metus hendrerit auctor dapibus justo porta. </p> 
 
    </div> 
 
    <div id="tab-4" class="tab-content"> 
 
     <p>Proin sollicitudin tincidunt quam, in egestas dui tincidunt non. Maecenas tempus condimentum mi, sed convallis tortor iaculis eu. Cras dui dui, tempor quis tempor vitae, ullamcorper in justo. Integer et lorem diam. Quisque consequat lectus eget 
 
     urna molestie pharetra. Cras risus lectus, lobortis sit amet imperdiet sit amet, eleifend a erat. Suspendisse vel luctus lectus. Sed ac arcu nisi, sit amet ornare tellus. Pellentesque nec augue a nibh pharetra scelerisque quis sit amet felis. 
 
     Nullam at enim at lacus pretium iaculis sit amet vel nunc. Praesent sapien felis, tincidunt vitae blandit ut, mattis at diam. Suspendisse ac sapien eget eros venenatis tempor quis id odio. Donec lacus leo, tincidunt eget molestie at, pharetra 
 
     cursus odio. </p> 
 
    </div> 
 
    </div> 
 
</div> 
 
<br/> 
 
<button id="tab-switch">change tab</button>

+0

@これは正常に正常に動作しています。 –

+0

どうすればいいですか?ユーザーが外部ボタンをクリックするたびに、最初のタブとコンテンツを選択する必要がある場合。 –

+0

それで、私はあなたの "タブセレクタ"コードから関数を作りました。 "setCurrentTab"を "a" HTML要素で呼び出すだけで済むようになりました。これは 'setCurrentTab($ tabsMenu。最初のタブが必要な場合は、現在の "nextTabId"は0にする必要があります。 'setCurrentTab($ tabsMenu.children()[0] .childNodes [ 0]) 'である。 '$ tabsMenu.children()'は、$ tabsMenuのchildren要素から配列を作ります。&childNodesは同じことをします。したがって、あなたの "li"には"a"要素 – skornous

関連する問題