JQuery Простая навигация по вкладкам - PullRequest
2 голосов
/ 01 апреля 2011

Мне нужна простая навигация без использования какого-либо плагина, но простой JQuery.

Ссылка 1 Div 1, Div 2, Div 3, Div 4
Ссылка 2
Ссылка 3
Ссылка 4

Когда пользователь щелкает ссылку 1, показывать Div 1 и скрывать все остальные div. Затем ссылка 2 показывает Div2 и скрывает все остальные. Я хочу сделать это с меньшим количеством строк.

Ответы [ 5 ]

2 голосов
/ 01 апреля 2011

Вот фрагмент кода, который я использую все время ( оригинал ): JS:

    $(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;
    });

});

css (много областей улучшения здесь хе-хе):

ul.tabs {
    margin: 0;
    padding: 0;
    float: left;
    list-style: none;
    height: 32px; /*--Set height of tabs--*/
    border-bottom: 1px solid #999;
    border-left: 1px solid #999;
    width: 100%;
}
ul.tabs li {
    float: left;
    margin: 0;
    padding: 0;
    height: 31px; /*--Subtract 1px from the height of the unordered list--*/
    line-height: 31px; /*--Vertically aligns the text within the tab--*/
    border: 1px solid #999;
    border-left: none;
    margin-bottom: -1px; /*--Pull the list item down 1px--*/
    overflow: hidden;
    position: relative;
    background: #e0e0e0;
}
ul.tabs li a {
    text-decoration: none;
    color: #000;
    display: block;
    font-size: 1.2em;
    padding: 0 20px;
    border: 1px solid #fff; /*--Gives the bevel look with a 1px white border inside the list item--*/
    outline: none;
}
ul.tabs li a:hover {
    background: #ccc;
}
html ul.tabs li.active, html ul.tabs li.active a:hover  { /*--Makes sure that the active tab does not listen to the hover properties--*/
    background: #fff;
    border-bottom: 1px solid #fff; /*--Makes the active tab look like it's connected with its content--*/
}

.tab_container {
    border: 1px solid #999;
    border-top: none;
    overflow: hidden;
    clear: both;
    float: left; width: 100%;
    background: #fff;
}
.tab_content {
    padding: 20px;
    font-size: 1.2em;
}

разметка:

    <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">
        asdfasdfasdfasdf
    </div>
    <div id="tab2" class="tab_content">
        asdfasdf
    </div>
</div>

Надеюсь, это поможет

1 голос
/ 01 апреля 2011

Я сделал один для вас на jsfiddle , надеюсь, это поможет.веселит

0 голосов
/ 23 декабря 2014

Вы можете проверить этот компонент на jsFiddle .

Может также использоваться, если вы хотите заполнить динамически.

$(document).ready(function() {
$.each($('.tabwrapper .tabmenu ul.nav li'), function(i) {
    $(this).attr('data-tab', i);
});
$.each($('.tabwrapper .tabcontent .tabs'), function(i) {
    $(this).attr('data-tab', i);
});
$('.tabwrapper .tabmenu ul.nav li a').click(function() {
    var parent = $(this).parent(),
        dataId = parent.data('tab');
    if (!parent.hasClass('active')) {
        $('.tabwrapper .tabmenu ul.nav li').removeClass('active');
        parent.addClass('active');
        $('.tabwrapper .tabcontent .tabs').hide();
        $('.tabwrapper .tabcontent .tabs[data-tab="' + dataId + '"]').fadeIn();
    }
});

});

0 голосов
/ 02 сентября 2014

вот простой скрипт, просто добавьте его в свой файл, и он будет работать, также не конфликтуя с другими существующими скриптами.

См. Демонстрацию: http://simple -jquery-responseive-tab.blogspot.в /

0 голосов
/ 01 апреля 2011

Любая причина, почему вы не хотите использовать плагин? Вот отличный плагин, который сделает все, что вы просите: http://flowplayer.org/tools/tabs/index.html

...