- 浏览: 15142 次
- 性别:
- 来自: 北京
文章分类
最新评论
解决方案1:
调用windows 的shell,但会有安全问题.
* browseFolder.js
* 该文件定义了BrowseFolder()函数,它将提供一个文件夹选择对话框
* 以供用户实现对系统文件夹选择的功能
* 文件夹选择对话框起始目录由
* Shell.BrowseForFolder(WINDOW_HANDLE, Message, OPTIONS, strPath)函数
* 的strPath参数设置
* 例如:0x11--我的电脑
* 0 --桌面
* "c:\\"--系统C盘
*
* 用如下代码把该函数应用到一个HTML文件中:
* <script src="browseFolder.js"></script>
* 或把下面代码直接COPY到<script language="javascript">...</script>标签中;
* 特别注意的是,由于安全方面的问题,你还需要如下设置才能使本JS代码正确运行,
* 否者会出现"没有权限"的问题.
*
* 1、设置可信任站点(例如本地的可以为:http://localhost)
* 2、其次:可信任站点安全级别自定义设置中:设置下面的选项
* "对没有标记为安全的ActiveX控件进行初始化和脚本运行"----"启用"
调用windows 的shell,但会有安全问题.
* browseFolder.js
* 该文件定义了BrowseFolder()函数,它将提供一个文件夹选择对话框
* 以供用户实现对系统文件夹选择的功能
* 文件夹选择对话框起始目录由
* Shell.BrowseForFolder(WINDOW_HANDLE, Message, OPTIONS, strPath)函数
* 的strPath参数设置
* 例如:0x11--我的电脑
* 0 --桌面
* "c:\\"--系统C盘
*
* 用如下代码把该函数应用到一个HTML文件中:
* <script src="browseFolder.js"></script>
* 或把下面代码直接COPY到<script language="javascript">...</script>标签中;
* 特别注意的是,由于安全方面的问题,你还需要如下设置才能使本JS代码正确运行,
* 否者会出现"没有权限"的问题.
*
* 1、设置可信任站点(例如本地的可以为:http://localhost)
* 2、其次:可信任站点安全级别自定义设置中:设置下面的选项
* "对没有标记为安全的ActiveX控件进行初始化和脚本运行"----"启用"
- /***
- 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);
- }
- }
使用的时候:
2.解决方案二:
自己写一个js读取本地硬盘的选择框, 缺点是外观上较上一个差一些.
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
- <title>无标题文档</title>
- </head>
- <body>
- <table border="0" cellpadding="0" width="100%" id="tb_show">
- <tr>
- <td width="18%">文件保存位置:</td>
- <td width="82%">
- <%--<html:file property="file" size="40" styleClass="inputbox"/>--%>
- <input name="backDir" type="text" value ="C:\" size="100" width="500">
- </td>
- </tr>
- <tr>
- <td>目录位置:</td>
- <td>
- <select name="tables_drive" id="tables_drives" onchange="get_drives()" ></select>
- </td>
- </tr>
- <tr>
- <td colspan="2">
- <select name="table_folder" id="table_folder" size="10" multiple ondblclick="get_file()"></select>
- </td>
- </tr>
- <tr>
- <td colspan="2">
- <font color="red">说明:双击列表框的一个选项,就将该文件夹下面的文件夹显示在该列表框中。第一个就是根目录</font>
- </td>
- </tr>
- </table>
- </body>
- </html>
- <script>
- /**//*
- *初始化,将系统所有的驱动器放入table_drives列表
- */
- window.onload = new function init()
- {
- var fso, s, n, e, x;
- fso = new ActiveXObject("Scripting.FileSystemObject");
- e = new Enumerator(fso.Drives);
- s = "";
- for (; !e.atEnd(); e.moveNext())
- {
- x = e.item();
- s = s + x.DriveLetter;
- s += ":";
- if (x.DriveType == 3)
- n = x.ShareName;
- else if (x.IsReady)
- n = x.VolumeName;
- else
- n = "[驱动器未就绪]";
- s += n + ",";
- }
- var drives = s.split(",");
- var tableDrives = document.getElementById("tables_drives");
- for ( var i = 0; i < drives.length-1; i++ )
- {
- var option = document.createElement("OPTION");
- drives[i].split(":");
- option.value = "["+drives[i].split(":")[0]+":]"+drives[i].split(":")[1];
- option.text = "["+drives[i].split(":")[0]+":]"+drives[i].split(":")[1];
- tableDrives.add(option);
- }
- }
- /**//*
- *tables_drives列表中选中的驱动器上所有文件夹放入table_folder列表中
- */
- function get_drives()
- {
- var tableDrives = document.getElementById("tables_drives");
- var tableFolders = document.getElementById("table_folder");
- for ( var i = 0; i < tableDrives.options.length; i++ )
- {
- if ( tableDrives.options[i].selected == true )
- {
- var fso, f, fc, s;
- var drive = tableDrives.options[i].value.split(":")[0].substring(1,tableDrives.options[i].value.split(":")[0].length);
- document.getElementById("backDir").value = drive + ":\\";
- fso = new ActiveXObject("Scripting.FileSystemObject");
- if (fso.DriveExists(drive))
- {
- d = fso.GetDrive(drive);
- if ( d.IsReady )
- {
- f = fso.GetFolder(d.RootFolder);
- fc = new Enumerator(f.SubFolders);
- s = "";
- for (;!fc.atEnd(); fc.moveNext())
- {
- s += fc.item();
- s += ",";
- }
- var len = tableFolders.options.length;
- while(len >= 0)
- {
- tableFolders.options.remove(len);
- len--;
- }
- var option = document.createElement("OPTION");
- option.value = drive + ":\\";
- option.text = drive + ":\\";
- tableFolders.add(option);
- var folders = s.split(",");
- for ( j = 0; j < folders.length -1; j++)
- {
- option = document.createElement("OPTION");
- option.value = folders[j];
- option.text = folders[j];
- tableFolders.add(option);
- }
- }
- else
- {
- alert("无法改变当前内容!")
- }
- }
- else
- return false;
- }
- }
- }
- /**//*
- *table_folder双击选项中的一个选项,就将该文件夹下面的文件夹显示在table_folder列表中。
- */
- function get_file()
- {
- var tableFolders = document.getElementById("table_folder");
- var tableDrives = document.getElementById("tables_drives");
- for ( var i = 0; i < tableFolders.options.length; i++ )
- {
- if ( tableFolders.options[i].selected == true )
- {
- var fso, f, fc, s;
- var folderpath = tableFolders.options[i].value.substring(0,tableFolders.options[i].value.length);
- if ( folderpath.charAt(folderpath.length-1) == "\\" )
- {
- document.getElementById("backDir").value = folderpath;
- }
- else
- {
- document.getElementById("backDir").value = folderpath + "\\";
- }
- fso = new ActiveXObject("Scripting.FileSystemObject");
- f = fso.GetFolder(folderpath);
- fc = new Enumerator(f.SubFolders);
- s = "";
- for (;!fc.atEnd(); fc.moveNext())
- {
- s += fc.item();
- s += ",";
- }
- var len = tableFolders.options.length;
- while(len >= 0)
- {
- tableFolders.options.remove(len);
- len--;
- }
- var opt = "";
- var opt1 = "";
- for ( j = 0; j < folderpath.split("\\").length; j++ )
- {
- var option = document.createElement("OPTION");
- opt = opt + folderpath.split("\\")[j]+"\\";
- if ( j > 0)
- {
- opt1 = opt;
- option.value = opt1.substring(0,opt1.length-1);
- option.text = opt1.substring(0,opt1.length-1);
- tableFolders.add(option);
- }
- else
- {
- option.value = opt;
- option.text = opt;
- tableFolders.add(option);
- }
- }
- if ( tableFolders.options[0].value == tableFolders.options[1].value )
- {
- tableFolders.options.remove(1);
- }
- if ( s != "" )
- {
- var folders = s.split(",");
- for ( j = 0; j < folders.length -1; j++)
- {
- option = document.createElement("OPTION");
- option.value = folders[j];
- option.text = folders[j];
- tableFolders.add(option);
- }
- }
- }
- }
- }
- </script>
发表评论
-
js全选或全不选
2013-01-30 10:26 5451.<!DOCTYPE html PUBLIC &quo ... -
js隐藏错误
2012-12-07 19:20 1017<script language="JavaS ... -
input file 按钮值
2012-10-18 12:42 715<html> <head> <t ... -
ectable当后台传过来金额是科学计数法时我们通过什么方式改变成普通的计数法
2012-04-27 08:41 1289<ec:table items="list&q ... -
JS-Jquery实现动态的add和delete<input type="text">
2012-02-25 13:46 2256<!DOCTYPE HTML PUBLIC " ...
相关推荐
2.jpg|3.jpg|4.jpg|5.jpg&bcastr_link=http://www.baidu.com|http://www.google.com|http://www.sina.com.cn|http://bbs.crsky.com|http://www.blogjava.net/supercrsky&bcastr_title=百度|谷歌|新浪|霏凡|我的博客&...
【资源说明】 基于微信小程序的校园论坛;微信小程序;云开发;云数据库;云储存;云函数;纯JS无后台;全部资料+详细文档+高分项目.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!
单电阻采样 基于单电阻采样的相电流重构算法 keil完整工程。 单电阻采样 f103的单电阻,完整工程,带文档,带硬件资料。 f3平台的单电阻完整工程,代码详细注释。 还有微芯的单电阻smo代码加文档 具体如截图请看下
jQuery左侧导航右侧tab页面切换
哈希查找
五相电机邻近四矢量SVPWM模型_MATLAB_Simulink仿真模型包括: (1)原理说明文档(重要):包括扇区判断、矢量作用时间计算、矢量作用顺序及切时间计算、PWM波的生成; (2)输出部分仿真波形及仿真说明文档; (3)完整版仿真模型:Simulink仿真模型; 注意,只包含五相电机邻近四矢量SVPWM算法,并非五相电机双闭环矢量控制,如果想要五相电机双闭环矢量控制资料,另一个链接。 资料介绍过程十分详细
法码滋.exe法码滋2.exe法码滋3.exe
项目包含完整前后端源码和数据库文件,均测试可正常运行 环境说明: 开发语言:Java 框架:ssm,mybatis JDK版本:JDK1.8 数据库:mysql 5.7 数据库工具:Navicat11 开发软件:eclipse/idea Maven包:Maven3.3 部署容器:tomcat7
算法允许用户在图像上自行划定标签,并对这些区域内的图像进行肤色检测和处理;最后在一个PyQt窗口中显示处理后的三张图片,分别为带标签图片,二值化图片,膨胀后图片。
内容概要: 本资料包含了一系列用于庆祝浪漫节日的创意代码,主要包括爱心代码和圣诞树代码。这些代码可以生成视觉上吸引人的图案和动画,用于在屏幕上展示爱心和圣诞树,增加节日气氛。爱心代码可以用于表达爱意,而圣诞树代码则适合在圣诞节期间使用,为用户带来节日的欢乐和视觉享受。 适用人群: 本资料适用于以下人群: 程序员和开发者,他们希望在项目中添加节日元素或为特别场合创造个性化的视觉效果。 网页设计师,他们需要为网站或应用程序添加节日主题的装饰。 技术爱好者和DIY爱好者,他们喜欢通过编程来庆祝节日或为朋友和家人制作特别的礼物。 实现:可直接运行python程序。
1. 患者信息与隔离状态管理 患者基本信息录入:对于疑似、确诊或密切接触者患者,系统记录其基本信息,包括姓名、年龄、性别、联系方式、住址等。 疫情风险评估:通过问卷或医务人员评估,系统对患者进行风险评估,判断是否需要隔离、隔离的级别(如轻症、中症、重症等)。 隔离状态管理:记录患者的隔离状态(如隔离中、已解除隔离、转入ICU等),并能够实时更新隔离状态变化。 隔离病房分配:根据患者的病情、感染风险和病房资源,系统自动分配适当的隔离病房或床位,避免交叉感染。 2. 隔离病房与环境管理 病房信息管理:系统对每个隔离病房进行实时监控,包括病房的床位使用情况、设备设施、清洁消毒状况等,确保每个病房的隔离效果。 空气流通与环境消毒管理:记录隔离病房的空气流通情况、消毒记录、物品消耗等,确保符合疫情防控要求。 设备与物资分配:针对隔离病房的特殊需求,系统可以自动化管理医疗设备(如氧气、呼吸机等)与防护物资(如口罩、手套、防护服等)的分配与库存管理。 3. 医护人员防护与工作管理 医护人员排班与防护管理:为隔离病房的医护人员进行特殊排班,避免交叉感染,并根据需要分配适当的防护装备,如全身防护服、N9
适配文章:https://editor.csdn.net/md?not_checkout=1&spm=1011.2415.3001.6217&articleId=144663667 富芮坤FR8003作为主机连接FR8003二:官方代码主从的UUID和att_idx
内容概要:文章介绍了USB PD协议单口控制器DP3145D的技术特点、主要功能和应用场景。DP3145D支持USB Type-C和USB Power Delivery(PD)3.1协议,具备多种配置选项,最高输出功率45W。它集成了CV环路光耦驱动电路、反馈网络电阻以及多项保护措施,适用于ACDC适配器等USB充电设备。 适合人群:电子工程师、电源产品设计师和技术研究人员。 使用场景及目标:主要用于设计和开发支持USB PD协议的ACDC适配器和充电设备,实现高效、安全的充电解决方案。 阅读建议:重点关注DP3145D的具体技术参数、功能特点和典型应用实例,结合自身需求进行产品选型和设计。
VBA视频教程 05
基于Spring Boot框架的网上蛋糕销售系统_30z8r428_231-wx.zip
matlab
蜡笔小新-去掉动效.zip
1221额的2的2的2额
济宁市2005-2024年近20年的历史气象数据,每3小时更新一次数据,参数包含气温、气压、降水量、云层、能见度、风向、湿度等,几万条数据
8.40 最新版本Saturn_PCB_Toolkit安装包,,eda 设计 PCB设计辅助工具,软件功能强大,单端线阻抗、差分线阻抗到串扰分析等多种计算工具