javascript - 在 PHP 中提取缩略图

标签 javascript php jquery html

我有一个 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>
</div>

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

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

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

stackoverflow 成员“JFK”告诉我我可以这样做:“$slide_images[$filename] = "<img src='{$filename}' alt='{$filename}' />"; 可以更改为 $slide_images[$filename] = "<a class='fancybox' data-fancybox-group='thumb1' href='{$filename}'><img src='{$filename}' alt='{$filename}' /></a>"; ...唯一的问题是您将使用与缩略图相同的图像,这将会增加页面加载的开销。"

并建议使用本教程:http://www.picssel.com/create-a-filtered-image-gallery-with-jquery-and-fancybox-part-2-create-image-thumbnails-with-php/

但是我没能成功。 有什么帮助吗?

最佳答案

在“JFK”建议中,您应该将 src 属性指向您的缩略图(并让 href 属性指向大尺寸图像)

有点像

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

因此缩略图会立即加载,但只有在需要时才会加载大图。

关于javascript - 在 PHP 中提取缩略图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31646285/

相关文章:

javascript - 如何使用 React-Router 3 使 Route 中的参数成为可选参数?

php - Laravel - 碳时代

javascript - json_decode 后未定义索引

javascript - 复制从另一个表单输入的文件路径

javascript - 如何在jquery中查找类型是select还是input

javascript - CSS/Javascript - 使用 css3 或 javascript 复制图像样式(贴纸样式)

javascript - 当它在 Promise 链中时,如何获得 axios 响应?

javascript - Vue.Draggable 通过拖动到指定区域来删除项目

php - 使用 jquery 和 php 的动态导航栏(带图像)- 鼠标悬停效果问题

php - Laravel 表单请求 - 授权中的 $this->user() 与 auth()->user()