按上传/修改日期排序PHP代码


Sorting by upload/modified date PHP code

我试图让我的PHP代码通过上传/修改日期排序我的文件,但有问题。有人知道该怎么做吗或者给我指路吗?

下面是目前为止我的工作代码:
$dir = 'files';
$file_display = array('jpg', 'jpeg', 'png', 'gif');
if(file_exists($dir) == false){
echo 'Directory '''.$dir,''' not found!';
} else {
$dir_contents = scandir($dir);
foreach($dir_contents as $file){
    $file_type = strtolower(end(explode('.', $file)));
    if($file !== '.' && $file !== '..' && in_array($file_type, $file_display) == true){
        echo '<img src="', $dir, '/', $file,'" alt="', $file, '" width="700" height="700" />';
        echo "<br />'n<br />'n";
    }
}
}

您可以通过PHP的usort()函数对文件名进行排序,如下所示:

usort($dir_contents, create_function('$a,$b', 'return filemtime("'.$dir.'/$a")<filemtime("'.$dir.'/$b");'));

上面按照文件的最后修改时间对数组进行排序。为了按文件的创建时间排序,您可以用filectime函数替换filemtime(您也可以检查Unix中的返回值含义的官方文档),或者从数据库中记住/检索文件上传时间。上面的紧凑php排序就是基于这个答案的。

另一种方法是在Javascript中对图像进行排序。你的PHP代码看起来像这样:

<div id="container">
<?php
$dir = 'files';
$file_display = array('jpg', 'jpeg', 'png', 'gif');
if(file_exists($dir) == false){
    echo 'Directory '''.$dir,''' not found!';
} else {
    $dir_contents = scandir($dir);
    foreach($dir_contents as $file){
        if($file == '.' || $file == '..') { continue; }
        $arr = explode('.',$file);
        $file_type = strtolower(end($arr));
        if(in_array($file_type, $file_display)){
            echo '<img src="', $dir, '/', $file,'" alt="', $file,
                '" data-m="', filemtime("$dir/$file"),
                '" data-u="', filectime("$dir/$file"), '" />';
        }
    }
}
?>
</div>

及相关javascript

var container, images, arr;
function prepare_images(){
    container = document.getElementById('container');
    images = container.getElementsByTagName('img');//nodeList object
    arr = [];
    for (var i=0;i<images.length;i++) {
        arr[i] = images[i];
    }
    sort_images('data-m');
}
function sort_images(attr){
    arr.sort(function(a,b){
        return parseInt(a.getAttribute(attr),10) - parseInt(b.getAttribute(attr),10);
    });
    for (var i=0;i<arr.length;i++) {
      container.appendChild(arr[i]);
    }
}
if (window.addEventListener) {
    window.addEventListener("load", prepare_images, false);
} else if (window.attachEvent) {
    window.attachEvent("onload", prepare_images); //for IE5-8
}

test.php @ pastebin