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代码  
/*** 
    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);  
    }  
}  
/***
    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代码  
  
                              
                          
                          
                                                             value="选择生成路径" />  
                          

                           
                       
                       
                                                            value="选择生成路径" />
                       
 2.解决方案二:
 自己写一个js读取本地硬盘的选择框, 缺点是外观上较上一个差一些.

 

Js代码  
  
  
  
无标题文档  
  
  
          
          
            文件保存位置:  
               
                <%----%>  
                  
              
          
          
          
            目录位置:  
               
                  
              
          
          
              
                          
                  
              
          
  
          
              
                说明:双击列表框的一个选项,就将该文件夹下面的文件夹显示在该列表框中。第一个就是根目录  
              
          
  
  

  

DEMO下载地址:https://dwz.cn/fgXtRtnu

你可能感兴趣的:(javascript Web上传文件夹的两种解决方案)