Слайдер Jquery загружает каждую вкладку
У меня проблема с вкладками jquery и слайдером. Моя проблема в том, что когда я щелкаю элемент слайдера, например, элемент слайдера, например, 4, он загружает каждую вкладку примерно по 4 элементам. можно загрузить только активную вкладку.
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();
ОБНОВИТЬ
Я думаю, вы говорите, что вам нужно добавить еще один класс для всех элементов слайдера. Затем, когда вы выбираете элемент вкладки, вам нужно скрыть соответствующие элементы слайдера.