javascript Web上传文件夹的两种解决方案

解决方案1:
调用windows 的shell,但会有安全问题.

 * browseFolder.js
 * 该文件定义了BrowseFolder()函数,它将提供一个文件夹选择对话框
 * 以供用户实现对系统文件夹选择的功能
 * 文件夹选择对话框起始目录由
 * Shell.BrowseForFolder(WINDOW_HANDLE, Message, OPTIONS, strPath)函数
 * 的strPath参数设置
 * 例如:0x11--我的电脑
 *   0 --桌面
 *  "c:\\"--系统C盘

 *
 * 用如下代码把该函数应用到一个HTML文件中:
 * 
 * 或把下面代码直接COPY到标签中;

 * 特别注意的是,由于安全方面的问题,你还需要如下设置才能使本JS代码正确运行,
 * 否者会出现"没有权限"的问题.

 *
 * 1、设置可信任站点(例如本地的可以为:http://localhost)
 * 2、其次:可信任站点安全级别自定义设置中:设置下面的选项
 * "对没有标记为安全的ActiveX控件进行初始化和脚本运行"----"启用"  

Js代码   收藏代码
  1. /*** 
  2.     path 要显示值的对象id 
  3. ****/  
  4. function browseFolder(path) {  
  5.     try {  
  6.         var Message = "\u8bf7\u9009\u62e9\u6587\u4ef6\u5939";  //选择框提示信息  
  7.         var Shell = new ActiveXObject("Shell.Application");  
  8.         var Folder = Shell.BrowseForFolder(0, Message, 64, 17);//起始目录为:我的电脑  
  9.   //var Folder = Shell.BrowseForFolder(0,Message,0); //起始目录为:桌面  
  10.         if (Folder != null) {  
  11.             Folder = Folder.items();  // 返回 FolderItems 对象  
  12.             Folder = Folder.item();  // 返回 Folderitem 对象  
  13.             Folder = Folder.Path;   // 返回路径  
  14.             if (Folder.charAt(Folder.length - 1) != "\\") {  
  15.                 Folder = Folder + "\\";  
  16.             }  
  17.             document.getElementById(path).value = Folder;  
  18.             return Folder;  
  19.         }  
  20.     }  
  21.     catch (e) {  
  22.         alert(e.message);  
  23.     }  
  24. }  
/***
    path 要显示值的对象id
****/
function browseFolder(path) {
    try {
        var Message = "\u8bf7\u9009\u62e9\u6587\u4ef6\u5939";  //选择框提示信息
        var Shell = new ActiveXObject("Shell.Application");
        var Folder = Shell.BrowseForFolder(0, Message, 64, 17);//起始目录为:我的电脑
  //var Folder = Shell.BrowseForFolder(0,Message,0); //起始目录为:桌面
        if (Folder != null) {
            Folder = Folder.items();  // 返回 FolderItems 对象
            Folder = Folder.item();  // 返回 Folderitem 对象
            Folder = Folder.Path;   // 返回路径
            if (Folder.charAt(Folder.length - 1) != "\\") {
                Folder = Folder + "\\";
            }
            document.getElementById(path).value = Folder;
            return Folder;
        }
    }
    catch (e) {
        alert(e.message);
    }
}

 

使用的时候:

Js代码   收藏代码
  1.   
  2.                             "text" name="path" />  
  3.                           
  4.                           
  5.                             "button" οnclick="browseFolder('path')"  
  6.                                 value="选择生成路径" />  
  7.                           

                            
                        
                        
                            
                        

 2.解决方案二:
 自己写一个js读取本地硬盘的选择框, 缺点是外观上较上一个差一些.

 

Js代码   收藏代码
  1.   
  2.   
  3. "Content-Type" content="text/html; charset=gb2312">  
  4. 无标题文档  
  5.   
  6.   
  7. "0" cellpadding="0" width="100%" id="tb_show">          
  8.           
  9.             "18%">文件保存位置:  
  10.             "82%">   
  11.                 <%--"file" size="40"  styleClass="inputbox"/>--%>  
  12.                 "backDir" type="text" value ="C:\" size="100" width="500">  
  13.               
  14.           
  15.           
  16.           
  17.             目录位置:  
  18.                
  19.                 "tables_drive" id="tables_drives" οnchange="get_drives()" >  
  20.               
  21.           
  22.           
  23.               
  24.             "2">              
  25.                 "table_folder" id="table_folder"  size="10" multiple οndblclick="get_file()">  
  26.               
  27.           
  28.   
  29.           
  30.             "2">  
  31.                 "red">说明:双击列表框的一个选项,就将该文件夹下面的文件夹显示在该列表框中。第一个就是根目录  
  32.               
  33.           
  34.   
  35.   
  36.   
  37.  

你可能感兴趣的:(Web开发)