php - 将缩略图连接到使用 php 提取的图像

标签 php html css fancybox

我有一个 slider (flexslider),我用它来以下面 jsfiddle 中显示的形式显示图像...我优化了 slider ,以便它提取图像(使用数字命名,例如:12364、50046)根据其名称动态地从某个目录中获取。

JSFIDDLE:https://jsfiddle.net/atkumqpk/1/

提取图片的代码:

        <?php
function get_slide_images($folder, $images_per_slide = 10, $starts_with = '')
{

    $slide_images = false;

    // valid extensions
    $extensions = array(
        "jpg",
        "gif",
        "jpeg",
        "svg",
        "png",
        "bmp",
        "JPG"
    );

    // Implode the extensions array into a string:
    $extensions = implode(',', $extensions);

    if (file_exists($folder)) {

        // Get all the files with a valid extension in $folder:
        // (optionally filtered by $starts_with)
        foreach (glob($folder.'/{'.$starts_with.'}*.{'.$extensions.'}', GLOB_BRACE) as $filename) {
            $slide_images[$filename] = "<img src='{$filename}' alt='{$filename}' />";
        }

        if (!empty($slide_images)) {
            ksort($slide_images);
            $slide_images = array_chunk($slide_images, $images_per_slide);
        }

    }

    return $slide_images;
}

?>

        <div id="logo" class="logo" ><img src="logo.png"/></div>
        <p class="custom-class"><a href="">Go to the main website</a></p>

        <div id="menu" class="menu">
        <ul class="headlines">
             <li id="item1">
        <button>aaaaaaaa</button>
    </li>
    <li id="item2">
        <button>bbbbbbb</button>
    </li>
    <li id="item3">
        <button>ccccccc</button>
    </li>
    <li id="item4">
        <button>dddddddd</button>
    </li>
    <li id="item5">
        <button>eeeeeee eee.</button>
    </li>
    <li id="item6">
        <button>ffffff</button>
    </li>
    <li id="item7">
        <button>ggggggg</button>
    </li>

        </ul>
        </div>


     <div id="container">
<div id="first" class="inner-container">
   <div id="item11" class="item"> <a name="item11"></a>

                <div class="flexslider">

  <ul class="slides">
  <?php


$slider_kvp = get_slide_images("images", 10, "1");

/**
* Here we are going to generate the SLIDES
*/
if($slider_kvp) {

    $slider_list_html = array();

    foreach($slider_kvp as $slider_key => $slide_images) {

        $html_LI_list = "";
        $html_LI_list = "<li>";

        // Go through each image ...
        foreach($slide_images as $image_key => $image_value) {
            $html_LI_list .= $image_value;
        }

        $html_LI_list .= "</li>";

        $slider_list_html[$slider_key] = $html_LI_list;

    }

    // OUR SLIDES!
    $rendered_slider_list_html = implode(' ', $slider_list_html);
    echo "<ul class='slides'>{$rendered_slider_list_html}</ul>";

}

?>

  </ul>
</div>
            </div>
        </div>

现在的问题是,当我有原始 slider (在优化它之前)时,我将它连接到“fancybox”以显示缩略图和隐藏图像。但是现在我不知道如何将它连接到使用 php 提取的图像。

Fancybox 的代码。 JSFIDDLE:http://jsfiddle.net/ny9ytae5/2/

案例:在目录图像(我正在从中提取图像)中,我有以数字命名的图像(例如:54236),并且对于每个图像都有一个具有相同名称的等效文件夹(例如:图像 54236有一个文件夹 54236)。文件夹54236的内容是需要连接到图片54236的缩略图。 有帮助吗?

最佳答案

您必须编辑您的 php 代码,在其中为以下代码生成图像的 hmtl:

$slide_images[$filename] = '<a class="fancybox" data-fancybox-group="slide-N">';
$slide_images[$filename] .= "<img src='{$filename}' alt='{$filename}' />";
$slide_images[$filename] .= '</a>';

因此您将获得 fancybox 所需的精确标记,但您必须将 fancybox-data-group 属性设置为对一张幻灯片上的所有图像都相等(将“slide-N”替换为您实际的“slide-1”等),当 fancybox 将显示当前幻灯片上图像的拇指。 这是 jsfiddle例如,您将在之后得到什么。

关于php - 将缩略图连接到使用 php 提取的图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30994366/

相关文章:

html - 尝试在 CSS3 中创建选取框

php - 将数据库中带空格的数据插入数组

php - 将敏感数据安全地存储在数据库中

php - 拉维尔 : UTF-8 issue while exporting CSV

javascript - 使用 PHP 和 JavaScript 显示旋转图像

javascript - 如何查询以相同ID开头的多个元素,然后检查输入是否发生变化

javascript - Bootstrap 多选在 laravel View 中不起作用

css - 如何修复卡片元素的CSS边框?

html - Linux 或 Windows 虚拟主机等

javascript - DOM 级别有何不同,它们之间如何相互关联?