通常のimgタグの代わりに背景画像を使用するセミカスタムフクロウカルーセルがあります。スライダにlazyloadingを追加して、スライドがアクティブなときにイメージをロードするようにしたいと思います。フクロウカルーセルは素晴らしい機能を持っていますが、私はそれを働かせることはできません。これはどのように達成できますか?背景画像を使用するフクロウカルーセルでlazyloaderを使用する方法
マイスライダー:
// content articles
$slider = "SELECT * FROM `web_content` WHERE catid = 10 AND state = 1 AND featured = 1 ORDER BY ordering";
$slidercon = $conn->query($slider);
$slidercr = array();
while ($slidercr[] = $slidercon->fetch_array());
?>
<!-- Home - Slider -->
<!-- ++++++++++++++++++++++++++++++++++++++++ -->
<section class="service-header home_slide_header">
<?
$i = 1;
foreach($slidercr as $slider){
$i++;
$slider_bgs = $slider['images'];
$slider_background = json_decode($slider_bgs); // Split JSON
if($slider_background->{'image_fulltext'} != ''){
$bgimg = 'cms/'.$slider_background->{'image_fulltext'};
}else{
$bgimg = 'http://website/nl/cms/images/Projecten/Images/background_placeholder.jpg';
}
if($slider['id'] != ''){
$backgrounds .= '
<div class="lazy bg-slider sliderclass'.$i.'" style="background: url('.$bgimg.');
background-repeat:no-repeat;
-webkit-background-size:cover;
-moz-background-size:cover;
-o-background-size:cover;
background-size:cover;
background-position:top;">
</div>';
}
}
echo $backgrounds;
?>
<div class="container">
<div class="row">
<div id="owl-demo" class="owl-carousel owl-theme">
<?
$a = 1;
foreach($slidercr as $slider1){
$shortstr = substr($slider1['introtext'], 0, 100) . '...';
$a++;
if($slider1['id'] != ''){
$slidercontent .= '
<div class="item" data-src=".sliderclass'.$a.'">
<div class="bolletje"></div>
<p class="slide_header">'.$slider1['title'].'</p>
<div class="info_text">
'.strip_tags($shortstr).' <a class="bekijkprojectindex infolink" href="'.$slider1['alias'].'.html">Bekijk project</a>
</div>
</div>';
}
}
echo $slidercontent;
?>
</div>
</div>
</div>
</section>
?>
そして、私のカルーセルコード:
$(document).ready(function() {
var old = '';
function setOld(){
setTimeout(function(){
old = $(".center").find('.item').data("src");
$(old).fadeIn('1000');
},50)
}
var owl = $("#owl-demo");
owl.owlCarousel({
center: true,
loop:true,
lazyLoad:true,
autoplay: true, //Set AutoPlay to 3 seconds
responsiveClass:true,
responsive:{
0 :{
items:1,
loop:true
},
900 :{
items:3,
loop:true
},
},
nav: true,
navText: [ '<img src="home_slider/button_left.png" />', '<img src="home_slider/button_right.png" />' ],
navSpeed: false,
navElement: 'div',
navContainer: false,
navContainerClass: 'owl-nav',
navClass: [ 'owl-prev btn', 'owl-next btn' ],
onInitialized: setOld()
});
owl.on('changed.owl.carousel', function(event) {
$(old).fadeOut('1050');
setTimeout(function(){
var src = $(".center").find('.item').data("src");
$(src).fadeIn('1000');
old = src;
},50)
})
私は、次のpluginを使用したいが、私はまた、フクロウカルーセルが機能hereでビルドを持って参照してください。 どちらを使うのが最適ですか?単にlazyLoad: true,
を追加するだけでは機能しません。