热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

利用php+mcDropdown实现文件路径可在下拉框选择

以下是对php+mcDropdown实现文件路径可在下拉框进行选择的方法进行了详细的分析介绍,需要的朋友可以过来参考下
最近用php进行文件目录信息读取,在网上弄到下面一段代码:
//获取指定目录下的文件列表
//$path 指定的目录,默认为当前目录
//$ifchild 是否显示子目录文件列表,默认不显示
//$curpath 显示当前的路径,默认为从当前目录开始;这个主要是为了显示确定href路径
代码如下:
function openpath($path=".",$ifchild=false,$curpath=".")
{

$handle = opendir($path);
if($handle)
{
while(false !== ($file = readdir($handle)))
{
if ($file != "." && $file != "..")
{
$fullPath = $path.DIRECTORY_SEPARATOR.$file;
if(is_dir($fullPath))//如果是目录文件
{
if($ifchild)//如果设置了显示子目录
{
//递归
openpath($path.DIRECTORY_SEPARATOR.$file,$ifchild,$curpath.DIRECTORY_SEPARATOR.$file);
}
else
{
echo "
  • $file
  • \n";
    }
    }
    else if($file != basename(__FILE__))//排除当前执行脚本
    {
    echo "
  • $file
  • \n";
    }
    else
    {
    echo $file;
    }
    }
    }
    }
    closedir($handle);
    }

    因为自己要提供路径选择的功能,最好是有一个下拉菜单,里面有待选路径的显示,这样方便很多,于是自己改了改,把路径输出成一个无序列表。
    下面是一个取得当前文件下所有子文件路径的代码:
    代码如下:
    /*获取指定目录文件路径列表
    *$path 指定的目录,默认为当前目录
    *$ifchild 是否获取子目录文件列表,默认不获取
    *$curpath 显示当前的路径,默认为从当前目录开始
    *&$pach_html_srt 传递一个外部变量的引用进来,因为此方法有可能被递归调用,所以以这样的方式来保存
    * 一些信息,也可以用全局变量来实现,在函数内部变量改变也影响到外部。
    *&$path_ref_count 原理同上,一个计数标志,如果递归,计数器从上一次保存的值开始自增
    */
    function openpath($path=".",$ifchild=false,&$path_html_str,&$path_ref_count)
    {
    $handle = opendir($path);
    if($handle)
    {
    while(false !== ($file = readdir($handle)))
    {
    if ($file != "." && $file != "..")
    {
    $fullPath = $path.DIRECTORY_SEPARATOR.$file;
    if(is_dir($fullPath))//如果文件是目录
    {
    $path_html_str.='
  • ';
    $path_html_str.=$file.'
      ';
      if($ifchild)
      {
      //递归
      openpath($path.DIRECTORY_SEPARATOR.$file,$ifchild,&$path_html_str,&$path_ref_count);
      }
      $path_html_str.='
  • ';
    }
    }
    }
    }
    closedir($handle);
    }

    有了上面的方法,我就可以在前台用jquery mcDropdown插件来让用户可以通过下拉菜单选择想进入的目录,所以需要封装成指定格式:
    代码如下:
    $path_ref_count = 1;
    $path_html_str ='';
    openpath(".",true,&$path_html_str,&$path_ref_count);
    $path_html_str = '
      '.$path_html_str.'
    ';
    $path_html_str = str_replace ( "
      ", '', $path_html_str );

      这样我把$path_html_str传到前台,显示出来的就是一个符合mcDropdown要求的无序列表,就可以显示相应的待选列表了。
      完整代码如下:
      test.html
      代码如下:











      Please select a category:



      #categorymenu#



      test.php
      代码如下:
      //目录信息处理
      $path_ref_count = 1;
      $path_html_str ='';
      openpath(".",true,&$path_html_str,&$path_ref_count);
      $path_html_str = '
        '.$path_html_str.'
      ';
      $path_html_str = str_replace ( "
        ", '', $path_html_str );
        //var_dump($path_info);
        //var_dump($path_html_str);
        $str_buffer = file_get_contents (dirname(__FILE__).DIRECTORY_SEPARATOR.'test.html');
        $str_buffer = str_replace ( "#categorymenu#", $path_html_str, $str_buffer );
        $str_buffer = str_replace ( "#delim#", DIRECTORY_SEPARATOR, $str_buffer );
        echo $str_buffer;
        /*获取指定目录文件路径列表
        *$path 指定的目录,默认为当前目录
        *$ifchild 是否获取子目录文件列表,默认不获取
        *$curpath 显示当前的路径,默认为从当前目录开始
        *&$pach_html_srt 传递一个外部变量的引用进来,因为此方法有可能被递归调用,所以以这样的方式来保存
        * 一些信息,也可以用全局变量来实现,在函数内部变量改变也影响到外部。
        *&$path_ref_count 原理同上,一个计数标志,如果递归,计数器从上一次保存的值开始自增
        */
        function openpath($path=".",$ifchild=false,&$path_html_str,&$path_ref_count)
        {
        $handle = opendir($path);
        if($handle)
        {
        while(false !== ($file = readdir($handle)))
        {
        if ($file != "." && $file != "..")
        {
        $fullPath = $path.DIRECTORY_SEPARATOR.$file;
        if(is_dir($fullPath))//如果文件是目录
        {
        $path_html_str.='
      • ';
        $path_html_str.=$file.'
          ';
          if($ifchild)
          {
          //递归
          openpath($path.DIRECTORY_SEPARATOR.$file,$ifchild,&$path_html_str,&$path_ref_count);
          }
          $path_html_str.='
      • ';
        }
        }
        }
        }
        closedir($handle);
        }
        ?>

        jquery mcDropdown 插件可以在这里下载:http://www.givainc.com/labs/mcdropdown_jquery_plugin.htm
        推荐阅读
        • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
        • CSS3选择器的使用方法详解,提高Web开发效率和精准度
          本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
        • 知识图谱——机器大脑中的知识库
          本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
        • Voicewo在线语音识别转换jQuery插件的特点和示例
          本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
        • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
        • 本文介绍了如何使用jQuery和AJAX来实现动态更新两个div的方法。通过调用PHP文件并返回JSON字符串,可以将不同的文本分别插入到两个div中,从而实现页面的动态更新。 ... [详细]
        • 本文介绍了DataTables插件的官方网站以及其基本特点和使用方法,包括分页处理、数据过滤、数据排序、数据类型检测、列宽度自动适应、CSS定制样式、隐藏列等功能。同时还介绍了其易用性、可扩展性和灵活性,以及国际化和动态创建表格的功能。此外,还提供了参数初始化和延迟加载的示例代码。 ... [详细]
        • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
        • HTML5网页模板怎么加百度统计?
          本文介绍了如何在HTML5网页模板中加入百度统计,并对模板文件、css样式表、js插件库等内容进行了说明。同时还解答了关于HTML5网页模板的使用方法、表单提交、域名和空间的问题,并介绍了如何使用Visual Studio 2010创建HTML5模板。此外,还提到了使用Jquery编写美好的HTML5前端框架模板的方法,以及制作企业HTML5网站模板和支持HTML5的CMS。 ... [详细]
        • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
          本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
        • 从零基础到精通的前台学习路线
          随着互联网的发展,前台开发工程师成为市场上非常抢手的人才。本文介绍了从零基础到精通前台开发的学习路线,包括学习HTML、CSS、JavaScript等基础知识和常用工具的使用。通过循序渐进的学习,可以掌握前台开发的基本技能,并有能力找到一份月薪8000以上的工作。 ... [详细]
        • 本文介绍了在满足特定条件时如何在输入字段中使用默认值的方法和相应的代码。当输入字段填充100或更多的金额时,使用50作为默认值;当输入字段填充有-20或更多(负数)时,使用-10作为默认值。文章还提供了相关的JavaScript和Jquery代码,用于动态地根据条件使用默认值。 ... [详细]
        • 本文介绍了如何在Jquery中通过元素的样式值获取元素,并将其赋值给一个变量。提供了5种解决方案供参考。 ... [详细]
        • 本文介绍了使用jQuery实现图片预加载和等比例缩放的方法,同时提供了演示和相关代码。该方法可以重置图片的宽度和高度,并使图片在水平和垂直方向上居中显示。 ... [详细]
        • 获取ul中第一个li元素的五种方法和多个ul中第一个li元素的四种方法
          本文介绍了获取ul中第一个li元素的五种方法和多个ul中第一个li元素的四种方法,包括使用jQuery的选择器和遍历方法。通过这些方法,可以方便地获取到所需的元素,并进行相应的操作。 ... [详细]
        author-avatar
        非机动车地了
        这个家伙很懒,什么也没留下!
        PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
        Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有