Слайдер Jquery загружает каждую вкладку

У меня проблема с вкладками jquery и слайдером. Моя проблема в том, что когда я щелкаю элемент слайдера, например, элемент слайдера, например, 4, он загружает каждую вкладку примерно по 4 элементам. можно загрузить только активную вкладку.

FIDDLE

HTML

<title>jQuery UI Slider - Slider scrollbar</title>
<body>
    <div class="scroll-pane ui-widget ui-widget-header ui-corner-all">
        <div class="scroll-content">
            <div class="scroll-content-item ui-widget-header"></div>
            <div class="scroll-content-item ui-widget-header">
                <div class="arabadiv" onclick="yukle()" style="width:100px; height:100px; background-color: darkviolet "></div>
            </div>
            <div class="scroll-content-item ui-widget-header">
                <div style="width:100px; height:100px; background-color:red"></div>
            </div>
            <div class="scroll-content-item ui-widget-header">4</div>
            <div class="scroll-content-item ui-widget-header">5</div>
            <div class="scroll-content-item ui-widget-header">6</div>
            <div class="scroll-content-item ui-widget-header">7</div>
            <div class="scroll-content-item ui-widget-header">8</div>
            <div class="scroll-content-item ui-widget-header">9</div>
            <div class="scroll-content-item ui-widget-header">10</div>
            <div class="scroll-content-item ui-widget-header">11</div>
            <div class="scroll-content-item ui-widget-header">12</div>
            <div class="scroll-content-item ui-widget-header">13</div>
            <div class="scroll-content-item ui-widget-header">14</div>
            <div class="scroll-content-item ui-widget-header">15</div>
            <div class="scroll-content-item ui-widget-header">16</div>
            <div class="scroll-content-item ui-widget-header">17</div>
            <div class="scroll-content-item ui-widget-header">18</div>
            <div class="scroll-content-item ui-widget-header">19</div>
            <div class="scroll-content-item ui-widget-header">20</div>
        </div>
        <div class="scroll-bar-wrap ui-widget-content ui-corner-bottom">
            <div class="scroll-bar"></div>
        </div>
    </div>
    <div style="clear:left"></div>
    <div id="tabs" class="tabs-bottom">
        <ul>
            <li><a href="#tabs-1">Genel Bakış</a>
            </li>
            <li><a href="#tabs-2">Tasarım</a>
            </li>
            <li><a href="#tabs-3">Aksesuar</a>
            </li>
            <li><a href="#tabs-4">Model</a>
            </li>
            <li><a href="#tabs-5">Renk</a>
            </li>
            <li><a href="#tabs-6">Fiyat</a>
            </li>
        </ul>
        <div class="tabs-spacer"></div>
        <div style="width:auto; height:800px; background-color:red" id="tabs-1"></div>
        <div style="width:auto; height:900px; background-color:yellowgreen" id="tabs-2"></div>
        <div style="width:auto; height:800px; background-color:darkcyan" id="tabs-3"></div>
        <div style="width:auto; height:800px; background-color:bisque" id="tabs-4"></div>
        <div style="width:auto; height:800px; background-color:firebrick" id="tabs-5"></div>
        <div style="width:auto; height:800px; background-color:ghostwhite" id="tabs-6"></div>

ДЖАВА

$(function () {
    $("#tabs").tabs();

    // fix the classes
    $(".tabs-bottom .ui-tabs-nav, .tabs-bottom .ui-tabs-nav > *")
        .removeClass("ui-corner-all ui-corner-top")
        .addClass("ui-corner-bottom");

    // move the nav to the bottom
    $(".tabs-bottom .ui-tabs-nav").appendTo(".tabs-bottom");
});

$(function () {
    //scrollpane parts
    var scrollPane = $(".scroll-pane"),
        scrollContent = $(".scroll-content");

    //build slider
    var scrollbar = $(".scroll-bar").slider({
        slide: function (event, ui) {
            if (scrollContent.width() > scrollPane.width()) {
                scrollContent.css("margin-left", Math.round(
                ui.value / 100 * (scrollPane.width() - scrollContent.width())) + "px");
            } else {
                scrollContent.css("margin-left", 0);
            }
        }
    });

    //append icon to handle
    var handleHelper = scrollbar.find(".ui-slider-handle")
        .mousedown(function () {
        scrollbar.width(handleHelper.width());
    })
        .mouseup(function () {
        scrollbar.width("100%");
    })
        .append("<span class='ui-icon ui-icon-grip-dotted-vertical'></span>")
        .wrap("<div class='ui-handle-helper-parent'></div>").parent();

    //change overflow to hidden now that slider handles the scrolling
    scrollPane.css("overflow", "hidden");

    //size scrollbar and handle proportionally to scroll distance
    function sizeScrollbar() {
        var remainder = scrollContent.width() - scrollPane.width();
        var proportion = remainder / scrollContent.width();
        var handleSize = scrollPane.width() - (proportion * scrollPane.width());
        scrollbar.find(".ui-slider-handle").css({
            width: handleSize,
                "margin-left": -handleSize / 2
        });
        handleHelper.width("").width(scrollbar.width() - handleSize);
    }

    //reset slider value based on scroll content position
    function resetValue() {
        var remainder = scrollPane.width() - scrollContent.width();
        var leftVal = scrollContent.css("margin-left") === "auto" ? 0 : parseInt(scrollContent.css("margin-left"));
        var percentage = Math.round(leftVal / remainder * 100);
        scrollbar.slider("value", percentage);
    }

    //if the slider is 100% and window gets larger, reveal content
    function reflowContent() {
        var showing = scrollContent.width() + parseInt(scrollContent.css("margin-left"), 10);
        var gap = scrollPane.width() - showing;
        if (gap > 0) {
            scrollContent.css("margin-left", parseInt(scrollContent.css("margin-left"), 10) + gap);
        }
    }

    //change handle position on window resize
    $(window).resize(function () {
        resetValue();
        sizeScrollbar();
        reflowContent();
    });
    //init scrollbar size
    setTimeout(sizeScrollbar, 10); //safari wants a timeout
});

CSS

    .scroll-pane {
    overflow: auto;
    width: 99%;
    float:left;
}
.scroll-content {
    width: 2440px;
    float: left;
}
.scroll-content-item {
    width: 100px;
    height: 100px;
    float: left;
    margin: 10px;
    font-size: 3em;
    line-height: 96px;
    text-align: center;
}
.scroll-bar-wrap {
    clear: left;
    padding: 0 4px 0 2px;
    margin: 0 -1px -1px -1px;
}
.scroll-bar-wrap .ui-slider {
    background: none;
    border:0;
    height: 2em;
    margin: 0 auto;
}
.scroll-bar-wrap .ui-handle-helper-parent {
    position: relative;
    width: 100%;
    height: 100%;
    margin: 0 auto;
}
.scroll-bar-wrap .ui-slider-handle {
    top:.2em;
    height: 1.5em;
}
.scroll-bar-wrap .ui-slider-handle .ui-icon {
    margin: -8px auto 0;
    position: relative;
    top: 50%;
}
/* force a height so the tabs don't jump as content height changes */
 #tabs .tabs-spacer {
    float: left;
    height: 200px;
}
.tabs-bottom .ui-tabs-nav {
    clear: left;
    padding: 0 .2em .2em .2em;
}
.tabs-bottom .ui-tabs-nav li {
    top: auto;
    bottom: 0;
    margin: 0 .2em 1px 0;
    border-bottom: auto;
    border-top: 0;
}
.tabs-bottom .ui-tabs-nav li.ui-tabs-active {
    margin-top: -1px;
    padding-top: 1px;
}

2 ответа

Кстати, вы можете просто использовать JQuery Cycle Plugin, работает с обоими <div> а также <ul > элементы. Что решило бы многие ваши проблемы, не изобретая велосипед. Вы можете прочитать демонстрацию для начинающих, промежуточные или расширенные демонстрации, или что-то вроде этого, как хорошо.

<!-- Pull some Libraries-->
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.5/jquery.min.js"></script>
<script type="text/javascript" src="http://malsup.github.com/jquery.cycle.all.js"></script>
<!-- Slider code -->
<script type="text/javascript">
$('#slider').cycle('slideX');
</script>
<!-- Slider itself-->
<ul id="slider">
    <li><img src='img1.png' title='first image' /></li>
    <li><img src='img2.png' title='second image' /></li>
    <li><img src='img3.png' title='third image' /></li>
</ul>

Я изо всех сил пытаюсь понять, что ты имеешь в виду. Если вы хотите загрузить только выбранные элементы, вы можете сделать его класс равным идентификатору того, что вы хотите загрузить, а затем использовать его для определения того, что вы хотите загрузить.

HTML

<div id="selected_item" class="item_to_load">

Джава

var loadMe = document.getElementsById("selected_item");

function showOrLoad () {
   var $item-to-load = document.getElementsByClassName(loadMe); 
}

Возможно, вам нужно присвоить каждому элементу слайдера идентификатор?

Если вы дали всем элементам слайдера уникальный идентификатор, вы можете скрыть "класс" и показать "идентификатор".

т.е.

HTML

<div id="uniqueID" class="scroll-content-item ui-widget-header">14</div>

Jquery

$('.scroll-content-item').hide();
$('#uniqueID').show();

ОБНОВИТЬ

Я думаю, вы говорите, что вам нужно добавить еще один класс для всех элементов слайдера. Затем, когда вы выбираете элемент вкладки, вам нужно скрыть соответствующие элементы слайдера.

Другие вопросы по тегам