@VladimirBolotov

Как остановить слайдер после того, как закончатся элементы?

Всем привет!

У меня есть слайдер
$(document).ready(function() {	
    $("a.photo").fancybox(
            {                       
          "padding" : 0,
          "imageScale" : false, 
            "zoomOpacity" : false,
            "zoomSpeedIn" : 1000,   
            "zoomSpeedOut" : 1000,  
            "zoomSpeedChange" : 1000, 
            "frameWidth" : 700,  
            "frameHeight" : 600, 
            "overlayShow" : true, 
            "overlayOpacity" : 0.7, 
            "hideOnContentClick" :false,
            "centerOnScroll" : false,		
			helpers: {		
				overlay: {			
				locked: false		
				}	
			}
                
            });					
			$(".fancy_photo").fancybox(	
			{			
				"padding" : 30,	
				wrapCSS    : 'fancy-slider',				
				helpers: {			
					overlay: {			
					locked: false			
					}			
				},			
				beforeShow  : function() {		
					$('.slider-for').slick({		
						slidesToShow: 1,				
						slidesToScroll: 1,					
						arrows: false,				
						fade: true,						
						asNavFor: '.slider-nav'					
					});					
					$('.slider-nav').slick({	
						slidesToShow: 4,		
						slidesToScroll: 1,		
						asNavFor: '.slider-for',	
						dots: false,				
						vertical:true,
						focusOnSelect: true,
						prevArrow : '<button type="button" class="slick-prev"></button>',
						nextArrow : '<button type="button" class="slick-next"></button>'							
					});											
				}			
				,afterClose: function ()		
				{				
					$('.slider-for').slick('unslick');	
					$('.slider-nav').slick('unslick');	
					}	
				});
});


Код вызова в template
<?foreach ($arResult["SECTIONS"] as $arSection) {?>
    <?foreach ($arSection["ELEMENTS"] as $arItem) {?>
<div class = "fancybox_slider" id = "slider_photo-<?=$arItem["ID"]?>">
    <div class = "slider-for">
        <?foreach ($arItem["PHOTO"] as $arPhoto) {
            ?><div><img src="<?=$arPhoto["SRC"]?>"></div><?
        }?>
    </div>
    <div class = "slider-nav">
        <?foreach ($arItem["PHOTO"] as $arPhoto) {
            ?><div><img src="<?=$arPhoto["SRC"]?>"></div><?
        }?>
    </div>
</div>
    <?
    }
}?>

result_modifier
$arSelect = array(
	'ID', 
	'IBLOCK_ID',
	'PROPERTY_PHOTO',
	'PREVIEW_PICTURE',
	'DETAIL_PICTURE'
	);

    foreach ($arResult["SECTIONS"] as &$arSection) {
        $rsPhotoElements = CIBlockElement::GetList(array("SORT" => "ASC", "NAME" => "ASC"), array("IBLOCK_ID" => $arParams["IBLOCK_ID"], "SECTION_ID" => $arSection["ID"], "ACTIVE" => "Y"), false, false, $arSelect);
        $i = 4;
        while ($i && $arElement = $rsPhotoElements->GetNext()) {
            $photo = CFile::ResizeImageGet($arElement["DETAIL_PICTURE"], array('width'=>200, 'height'=>180), BX_RESIZE_IMAGE_PROPORTIONAL);
            $arElement["PREVIEW_PICTURE"] = $photo['src'];
            $arElement["DETAIL_PICTURE"] = CFile::GetFileArray($arElement["DETAIL_PICTURE"]);
            $arElement["PHOTO"][] = $arElement["DETAIL_PICTURE"];
            foreach ($arElement["PROPERTY_PHOTO_VALUE"] as $mphoto) {
                $arElement["PHOTO"][] = CFile::GetFileArray($mphoto);
            }
            $arSection["ELEMENTS"][] = $arElement;
            $i--;
        }
    }

28a8669f44224fdfbfe8f6faed2c44b4.png
Слайдер рабочий. но! Он бесконечно пролистывается справа. Мне нужно, чтобы когда он доходит до последнего элемента, кнопка вниз пропадала и он останавливался.
  • Вопрос задан
  • 198 просмотров
Решения вопроса 1
zorro76
@zorro76
Если я правильно понял вашу проблему, то для того что-бы slick-slider не прокручивался, придумана функция: infinite: false;
ну а для того что бы стрелка как вы говорите пропадала то снова же магия css и самого slick-slider, по умолчанию кажется стрелка, на которую нельзя кликнуть, имеет в стилях: opacity: .25, рабочая стрелка имеет opacity: 1;
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
@justdealman
Ответ написан
Комментировать
Ваш ответ на вопрос

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

Похожие вопросы
28 нояб. 2024, в 05:21
2000 руб./за проект
28 нояб. 2024, в 05:18
500 руб./за проект
28 нояб. 2024, в 03:51
3500 руб./за проект