Задать вопрос
@Coraelstraze

Группировать изображения в галерее на jQuery?

Здравствуйте! Сайт просто на html. Ссылка на него: test.vetivdom.ru

На нем есть каталог домов. Если нажать на изображение или цену дома, открывается каталог, который состоит из текста и галереи изображений.
Так вот, проблема в том, что эта галерея работает будто бы целиком на весь сайт, т.е если открыть первый дом, то в нем откроется 1 картинка из всех заданных в галерее, и если открыть второй дом, открывается та же самая картинка.
Что нужно мне: чтобы скрипт галереи работал отдельно на каждый дом и открывал только миниатюры конкретного дома. Всю голову изломал, ума не приложу как это сделать.

340d16486d40402dbace47bae05fe8ad.png

d82e10368575482b8ee425c4bbeb7431.png

Скрипт галереи:

$(function() {
// ======================= imagesLoaded Plugin ===============================
// https://github.com/desandro/imagesloaded

// $('#my-container').imagesLoaded(myFunction)
// execute a callback when all images have loaded.
// needed because .load() doesn't work on cached images

// callback function gets image collection as argument
// this is the container

// original: mit license. paul irish. 2010.
// contributors: Oren Solomianik, David DeSandro, Yiannis Chatzikonstantinou

$.fn.imagesLoaded = function( callback ) {
var $images = this.find('img'),
len = $images.length,
_this = this,
blank = '';

function triggerCallback() {
callback.call( _this, $images );
}

function imgLoaded() {
if ( --len <= 0 && this.src !== blank ){
setTimeout( triggerCallback );
$images.off( 'load error', imgLoaded );
}
}

if ( !len ) {
triggerCallback();
}

$images.on( 'load error', imgLoaded ).each( function() {
// cached images don't fire load sometimes, so we reset src.
if (this.complete || this.complete === undefined){
var src = this.src;
// webkit hack from groups.google.com/group/jquery-dev/browse_thread/t...
// data uri bypasses webkit log warning (thx doug jones)
this.src = blank;
this.src = src;
}
});

return this;
};

// gallery container
var $rgGallery = $('#rg-gallery, #rg-gallery1, #rg-gallery2');
// carousel container

var $esCarousel = $rgGallery.find('div.es-carousel-wrapper'),
// the carousel items
$items = $esCarousel.find('ul > li'),
// total number of items
itemsCount = $items.length;

Gallery = (function() {
// index of the current item
var current = 0,
// mode : carousel || fullview
mode = 'carousel',
// control if one image is being loaded
anim = false,
init = function() {

// (not necessary) preloading the images here...
$items.add('ajax-loader.gifblack.png').imagesLoaded( function() {
// add options
_addViewModes();

// add large image wrapper
_addImageWrapper();

// show first image
_showImage( $items.eq( current ) );

});

// initialize the carousel
if( mode === 'carousel' )
_initCarousel();

},
_initCarousel = function() {

// we are using the elastislide plugin:
// tympanus.net/codrops/2011/09/12/elastislide-respon...
$esCarousel.show().elastislide({
imageW : 65,
onClick : function( $item ) {
if( anim ) return false;
anim = true;
// on click show image
_showImage($item);
// change current
current = $item.index();
}
});

// set elastislide's current to current
$esCarousel.elastislide( 'setCurrent', current );

},
_addViewModes = function() {

// top right buttons: hide / show carousel

var $viewfull = $(''),
$viewthumbs = $('');

$rgGallery.prepend( $('').append( $viewfull ).append( $viewthumbs ) );

$viewfull.on('click.rgGallery', function( event ) {
if( mode === 'carousel' )
$esCarousel.elastislide( 'destroy' );
$esCarousel.hide();
$viewfull.addClass('rg-view-selected');
$viewthumbs.removeClass('rg-view-selected');
mode = 'fullview';
return false;
});

$viewthumbs.on('click.rgGallery', function( event ) {
_initCarousel();
$viewthumbs.addClass('rg-view-selected');
$viewfull.removeClass('rg-view-selected');
mode = 'carousel';
return false;
});

if( mode === 'fullview' )
$viewfull.trigger('click');

},
_addImageWrapper= function() {

// adds the structure for the large image and the navigation buttons (if total items > 1)
// also initializes the navigation events

$('#img-wrapper-tmpl').tmpl( {itemsCount : itemsCount} ).appendTo( $rgGallery );

if( itemsCount > 1 ) {
// addNavigation
var $navPrev = $rgGallery.find('a.rg-image-nav-prev'),
$navNext = $rgGallery.find('a.rg-image-nav-next'),
$imgWrapper = $rgGallery.find('div.rg-image');

$navPrev.on('click.rgGallery', function( event ) {
_navigate( 'left' );
return false;
});

$navNext.on('click.rgGallery', function( event ) {
_navigate( 'right' );
return false;
});

// add touchwipe events on the large image wrapper
$imgWrapper.touchwipe({
wipeLeft : function() {
_navigate( 'right' );
},
wipeRight : function() {
_navigate( 'left' );
},
preventDefaultEvents: false
});

$(document).on('keyup.rgGallery', function( event ) {
if (event.keyCode == 39)
_navigate( 'right' );
else if (event.keyCode == 37)
_navigate( 'left' );
});

}

},
_navigate = function( dir ) {

// navigate through the large images

if( anim ) return false;
anim = true;

if( dir === 'right' ) {
if( current + 1 >= itemsCount )
current = 0;
else
++current;
}
else if( dir === 'left' ) {
if( current - 1 < 0 )
current = itemsCount - 1;
else
--current;
}

_showImage( $items.eq( current ) );

},
_showImage = function( $item ) {

// shows the large image that is associated to the $item

var $loader = $rgGallery.find('div.rg-loading').show();

$items.removeClass('selected');
$item.addClass('selected');

var $thumb = $item.find('img'),
largesrc = $thumb.data('large'),
title = $thumb.data('description');

$('').load( function() {

$rgGallery.find('div.rg-image').empty().append(''%20+%20largesrc%20+%20'');

if( title )
$rgGallery.find('div.rg-caption').show().children('p').empty().text( title );

$loader.hide();

if( mode === 'carousel' ) {
$esCarousel.elastislide( 'reload' );
$esCarousel.elastislide( 'setCurrent', current );
}

anim = false;

}).attr( 'src', largesrc );

},
addItems = function( $new ) {

$esCarousel.find('ul').append($new);
$items = $items.add( $($new) );
itemsCount = $items.length;
$esCarousel.elastislide( 'add', $new );

};

return {
init : init,
addItems : addItems
};

})();

Gallery.init();

/*
Example to add more items to the gallery:

var $new = $('1.jpg');
Gallery.addItems( $new );
*/
});
  • Вопрос задан
  • 421 просмотр
Подписаться 1 Оценить 2 комментария
Пригласить эксперта
Ответы на вопрос 1
@alexmixaylov
у вас размер странички больше 60Мб
не знаю точно сколько просто не стал дожидаться загрузки страницы
я бы за такую работу не заплатил :( ничего личного, но это никуда не годится

вам нужно пересмотреть структуру сайта
нет смысла что-то ремонтировать здесь

если это каталог - нет смысла все вываливать на главную старницу
лучше сделать навигацию и пусть клиент переходит по ссылке в нужную категорию и там смотрит

если такое не подходит
нужно использовать аякс
ссылки к изображениям выводить при помощи дата атрибутов
и аяксом подгружать те на которые кликнули
как то так
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы