递归获取文件夹id下所有子文件夹id和文件id

本文介绍如何利用PHP编程实现递归遍历一个文件夹ID下的所有子文件夹和文件ID,包括删除文件夹的相关操作。
摘要由CSDN通过智能技术生成
/**
 * 查询文件夹下的文件及文件夹
 */
 为了实现删除文件夹功能,写了这个方法,可以递归获取文件夹id下所有子文件夹id和文件id

public function getFileFolderIds($folder_id,$totals=[]){
    $total = $totals;
    if(is_array($folder_id)){
        $folder_id = implode(",", $folder_id);
            $sql1 = "SELECT id FROM yy_folder WHERE id in (".$folder_id.")" ;
            $sql2 = "SELECT id FROM yy_file WHERE folder_id in (".$folder_id .")";
            $file_ids = $this->db->query($sql1);
            foreach ($file_ids as $vv){
                $total["file_ids"][] = $vv;
            }
            $folder_ids = $this->db->query($sql2);
            foreach ($file_ids as $vvv){
                $total["folder_ids"][] = $vvv;
            }
            if($folder_ids){
                return  $this -> getFileFolderIds($folder_ids,$total);
            }else{
                return $total;
            }

    }else{
   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要列出文件夹下的所有图片,可以使用HTML5的新特性File API和JavaScript来实现。 首先,通过HTML的<input type="file">元素可以让用户选择文件夹,并将返回的文件列表存储在FileList对象中。我们可以使用<input type="file" multiple directory webkitdirectory>来实现选择文件夹的功能。 然后,在JavaScript中,我们可以使用FileReader对象的readEntries()方法来读取文件夹中的所有文件文件夹,并将它们存储在一个数组中。接着,我们可以通过递归遍历该数组,筛选出所有的图片文件,并将它们展示在页面上。 下面是一个基本的示例代码: HTML部分: ```html <input type="file" id="fileInput" multiple directory webkitdirectory> <div id="imageContainer"></div> ``` JavaScript部分: ```javascript function readFiles(entries) { entries.forEach(function(entry) { if (entry.isFile && entry.name.match(/\.(jpg|jpeg|png|gif)$/i)) { var img = document.createElement('img'); img.src = URL.createObjectURL(entry); document.getElementById('imageContainer').appendChild(img); } else if (entry.isDirectory) { var dirReader = entry.createReader(); dirReader.readEntries(readFiles); } }); } function handleFileSelect(event) { var files = event.target.files; var entries = []; for (var i = 0; i < files.length; i++) { var file = files[i]; var entry = file.webkitGetAsEntry(); entries.push(entry); } readFiles(entries); } var fileInput = document.getElementById('fileInput'); fileInput.addEventListener('change', handleFileSelect, false); ``` 在这个示例中,用户选择的文件夹中的所有图片文件将会被列出并显示在id为"imageContainer"的div元素中。你可以根据实际需求进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

宁静之峰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值