Slick Slider - 使用 php 实现会导致背景图像错误

2022-01-24 00:00:00 slider php javascript css slick.js

大家好,

我做了一个相当可爱的滑杆.

I have made a rather cute slick-slider.

在我让它使用 PHP 并将其托管在我的网站上之前,它是一种享受.

It works a treat before I make it utilise PHP and host it on my site.

	$(function() {
		//console.log( "ready!" );

		// SLIDER
			console.clear();

			var carousels = $('.funky-slider');
			var config = {
				dots: true,
				arrows: false,
				infinite: true,
				speed: 700,
				autoplay: false,
				autoplaySpeed: 5000,
				slidesToShow: 3,
				slidesToScroll: 1,
				swipeToSlide: true,
				pauseOnHover: false,
				responsive: [
					{
						breakpoint: 1024,
						settings: {
							slidesToShow: 2
						}
					},
					{
						breakpoint: 767,
						settings: {
							slidesToShow: 1
						}
					}
				]
			};
			carousels.slick(config);

			carousels.on('breakpoint', function(slick) {
				carousels.slick('setPosition');
				// console.log(slick.currentTarget.slick);
				var count = slick.currentTarget.slick.slideCount;
				var show = slick.currentTarget.slick.options.slidesToShow;

				if (show >= count) {
					carousels.slick('unslick');
				}

			});

			carousels.on('destroy', function() {
				carousels.slick(config);
			});
		// END SLIDER
	});

	/* FUNKY SLIDER */
		/* FUNCTIONAILTY */
      .funky-slider, .slick-track, .funky-slide {
        height: 400px;
      }
      .funky-slide {
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
      }
			.funky-slider .slick-slide {
				outline: none;
			}
			.funky-slider .slick-dots {
				width: 100%;
				height: 2rem;
				margin: 0;
				padding: 0.5rem 0;
				display: flex;
				align-items: center;
				justify-content: center;
				list-style-type: none;

				position: absolute;
				bottom: 0;
			}
				.funky-slider .slick-dots li {
					width: auto;
					height: auto;
					margin: 0 0.25rem;
				}
				.funky-slider .slick-dots button {
					display: block;
					width: 1rem;
					height: 1rem;
					padding: 0;
					border: 1px solid white;
					border-radius: 100%;
					background-color: #db3c36;
					color: transparent;
					-webkit-transition: width 0.5s, height 0.5s; /* Safari */
					transition: width 0.5s, height 0.5s;
					outline: none;
				}
					.funky-slider .slick-dots li.slick-active button {
						background-color: #241f21;
						width: 1.6rem;
						height: 1.6rem;
					}
		/* END FUNCTIONAILTY */
	/* FUNKY SLIDER */

<link rel="stylesheet" type="text/css" href="https://kenwheeler.github.io/slick/slick/slick.css"/>

<!-- HTML -->
<div class="funky-slider-container">
	<div class="funky-slider">
		<div class="funky-slide" style="background-image: url('https://usercontent2.hubstatic.com/12593011_f520.jpg')">
			Hello!
		</div>
		<div class="funky-slide">
			Hello!
		</div>
		<div class="funky-slide">
			Hello!
		</div>
		<div class="funky-slide">
			Hello!
		</div>
		<div class="funky-slide">
			Hello!
		</div>
		<div class="funky-slide">
			Hello!
		</div>
		<div class="funky-slide">
			Hello!
		</div>
		<div class="funky-slide">
			Hello!
		</div>
		<div class="funky-slide">
			Hello!
		</div>
		<div class="funky-slide">
			Hello!
		</div>
	</div>
</div>
<!-- END HTML -->

<!-- PHP SLIDER
	<?php
		$funky_slider = get_field('funky_slider');
	?>
  	<?php if( $funky_slider ) : ?>
		<section id="funky-slider" class="funky-slider-section">
			<div class="funky-slider">

				<?php while( have_rows('funky_slider') ): the_row();
					$funky_slider_image = get_sub_field('funky_slider_image');
				?>

					<div class="funky-slide" style="background-image: url('<?php echo $funky_slider_image['url'] ?>')"></div>

				<?php endwhile; ?>
			</div>
		</section>
	<?php endif; ?>
	-->
<!-- END PHP SLIDER -->

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script type="text/javascript" src="https://kenwheeler.github.io/slick/slick/slick.min.js"></script>

这个例子只显示了我的 HTML、JS、CSS 版本,我的 PHP 版本被注释掉了.

The example is only showing my HTML, JS, CSS version with my PHP version commented out.

然后我继续使用 ACF - Wordpress 中的高级自定义字段,并制作了相应的字段来生成图像 url.

I have then gone on to use ACF - Advanced Custom Fields within Wordpress and made the appropriate fields to generate an image url.

然后,如我注释掉的 php 代码所示 - 设置背景图像.

I then as illustrated in my commented out php code - set the background image.

页面将在全屏时漂亮地加载滑块(大于第一个断点 - 1024px).但是,当页面小于第一个断点时,将删除背景图像的内联样式.

The page will then load the slider beautifully when in full screen (larger than the first breakpoint - 1024px). However, will remove the inline-styles for the background-image when the page is made smaller than the first breakpoint.

这是因为光滑的滑块删除了内联样式吗?

Is this because slick slider removes inline styles?

最坏的情况——你们都会得到一个漂亮的滑杆入门套件...

Worst case scenario - you all get a beautiful slick slider starter kit...

谢谢,杰森.

推荐答案

我已经弄清楚发生了什么.输入响应式光滑设置时,它会删除内联样式.

I have figured out what is happening. When entering the responsive slick settings it removes inline-styles.

为了解决这个问题,我使用了以下代码:

To work around this I have used this code:

<!-- SLIDER -->
<?php
    $funky_slider = get_field('funky_slider');
?>
<?php if( $funky_slider ) : ?>

    <!-- generate image css -->
    <style>
        <?php
            $count = 1;
            while( have_rows('funky_slider') ): the_row();
            $funky_slider_image = get_sub_field('funky_slider_image');
        ?>

            .slick-slide:nth-of-type(<?php echo $count ?>) .funky-slide {
                background-image: url('<?php echo $funky_slider_image['url'] ?>');
            }

            <?php $count++; ?>

        <?php endwhile; ?>
    </style>
    <!-- END generate image css -->

    <!-- generate slider -->
    <section id="funky-slider" class="funky-slider-section">
        <div class="funky-slider">
            <?php
                while( have_rows('funky_slider') ): the_row();
            ?>

                <div class="funky-slide">
                </div>

            <?php endwhile; ?>
        </div>
    </section>
    <!-- END generate slider -->
<?php endif; ?>
<!-- END SLIDER -->

这将创建一个样式表,将背景图像应用于相关幻灯片.然后继续创建将被光滑的幻灯片.

This creates a style sheet that applies the background image to the relevant slide. Then goes on to create the slides that will be slicked.

希望我能帮助一些处于我这种情况的人.

Hope I have helped a few people in my situation.

谢谢,杰森.

相关文章