Как реализовать вкладки Jquery внутри элемента управления повторителем / сеткой? - PullRequest
2 голосов
/ 27 августа 2011

У меня есть повторитель управления.Внутри каждого элемента / записи у меня есть интерфейс с вкладками с 2 вкладками.Я реализую функциональность вкладок с Jquery.Но каждый раз, когда я нажимаю на любую вкладку на странице, переключаются только вкладки первого элемента / записи.Пожалуйста, дайте мне знать, как этого добиться.

<ul class="tabs">
    <li><a href="#tab1">Gallery</a></li>
    <li><a href="#tab2">Submit</a></li>
</ul>

<div class="tab_container">
    <div id="tab1" class="tab_content">
        <!--Content-->
    </div>
    <div id="tab2" class="tab_content">
       <!--Content-->
    </div>
</div>



$(document).ready(function() {

    //When page loads...
    $(".tab_content").hide(); //Hide all content
    $("ul.tabs li:first").addClass("active").show(); //Activate first tab
    $(".tab_content:first").show(); //Show first tab content

    //On Click Event
    $("ul.tabs li").click(function() {

        $("ul.tabs li").removeClass("active"); //Remove any "active" class
        $(this).addClass("active"); //Add "active" class to selected tab
        $(".tab_content").hide(); //Hide all tab content

        var activeTab = $(this).find("a").attr("href"); //Find the href attribute      value to identify the active tab + content
        $(activeTab).fadeIn(); //Fade in the active ID content
        return false;
    });

});

1 Ответ

1 голос
/ 27 августа 2011

Поскольку вы используете ids для добавления содержимого div в репитере.Все элементы повторителя будут иметь идентичные идентификаторы, поэтому ваша логика не будет.Попробуйте это

$(document).ready(function() {

    //When page loads...
    $(".tab_content").hide(); //Hide all content
    $("ul.tabs > li:first-child").addClass("active").show(); //Activate first tab
    $(".tab_content:first-child").show(); //Show first tab content

    //On Click Event
    $("ul.tabs > li").click(function() {

        $(this).siblings().removeClass("active"); //Remove any "active" class
        $(this).addClass("active"); //Add "active" class to selected tab

        var $tabContents = $(this).parent().next().children();
        $tabContents.hide(); //Hide all tab content

       // var activeTab = $(this).find("a").attr("href"); //Find the href attribute      value to identify the active tab + content

        //Use the index() method to get the tab to show 
        $tabContents.eq($(this).index()).fadeIn();

        return false;
    });

});

Также установите для свойства href anchor значение javascript:void(0), в противном случае страница будет прокручиваться при нажатии на вкладку.

...