`
jdw
  • 浏览: 161415 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JS 获取本地文件夹的文件列表[转]

    博客分类:
  • web
阅读更多

一、功能实现核心:FileSystemObject 对象 要在javascript中实现文件操作功能,主要就是依靠FileSystemobject对象。 二、FileSystemObject编程 使用FileSystemObject 对象进行编程很简单,一般要经过如下的步骤: 创建FileSystemObject对象、应用相关方法、访问对象相关属性 。 (一)创建FileSystemObject对象 创建FileSystemObject对象的 代码只要1行: var fso = new ActiveXObject("Scripting.FileSystemObject"); 上述代码执行后,fso就成为一个FileSystemObject对象实例。 (二)应用相关方法 创建对象实例后,就可以使用对象的相关方法了。比如,使用CreateTextFile方法创建一个文本文件: var fso = new ActiveXObject("Scripting.FileSystemObject"); var f1 = fso.createtextfile("c:\\myjstest.txt",true"); (三)访问对象相关属性 要访问对象的相关属性,首先要建立指向对象的句柄,这就要通过get系列方法实现:GetDrive负责获取驱动器信息,GetFolder负责获取文件夹信息,GetFile负责获取文件信息。比如,指向下面的代码后,f1就成为指向文件c:\test.txt的句柄: var fso = new ActiveXObject("Scripting.FileSystemObject"); var f1 = fso.GetFile("c:\\myjstest.txt"); 然后,使用f1访问对象的相关属性。比如: var fso = new ActiveXObject("Scripting.FileSystemObject"); var f1 = fso.GetFile("c:\\myjstest.txt"); alert("File last modified: " + f1.DateLastModified); 执行上面最后一句后,将显示c:\myjstest.txt的最后修改日期属性值。 但有一点请注意:对于使用create方法建立的对象,就不必再使用get方法获取对象句柄了,这时直接使用create方法建立的句柄名称就可以: var fso = new ActiveXObject("Scripting.FileSystemObject"); var f1 = fso.createtextfile("c:\\myjstest.txt",true"); alert("File last modified: " + f1.DateLastModified); 三、操作驱动器(Drives) 使用FileSystemObject对象来编程操作驱动器(Drives)和文件夹(Folders)很容易,这就象在Windows文件浏览器中对文件进行交互操作一样,比如:拷贝、移动文件夹,获取文件夹的属性。 (一)Drives对象属性 Drive对象负责收集系统中的物理或逻辑驱动器资源内容,它具有如下属性: l TotalSize:以字节(byte)为单位计算的驱动器大小。 l AvailableSpace或FreeSpace:以字节(byte)为单位计算的驱动器可用空间。 l DriveLetter:驱动器字母。 l DriveType:驱动器类型,取值为:removable(移动介质)、fixed(固定介质)、network(网络资源)、CD-ROM或者RAM盘。 l SerialNumber:驱动器的系列码。 l FileSystem:所在驱动器的文件系统类型,取值为FAT、FAT32和NTFS。 l IsReady:驱动器是否可用。 l ShareName:共享名称。 l VolumeName:卷标名称。 l Path和RootFolder:驱动器的路径或者根目录名称。 (二)Drive对象操作例程 下面的例程显示驱动器C的卷标、总容量和可用空间等信息: var fso, drv, s =""; fso = new ActiveXObject("Scripting.FileSystemObject"); drv = fso.GetDrive(fso.GetDriveName("c:\\")); s += "Drive C:" + " - "; s += drv.VolumeName + "\n"; s += "Total Space: " + drv.TotalSize / 1024; s += " Kb" + "\n"; s += "Free Space: " + drv.FreeSpace / 1024; s += " Kb" + "\n"; alert(s); 四、操作文件夹(Folders) 涉及到文件夹的操作包括创建、移动、删除以及获取相关属性。 Folder对象操作例程 : 下面的例程将练习获取父文件夹名称、创建文件夹、删除文件夹、判断是否为根目录等操作: var fso, fldr, s = ""; // 创建FileSystemObject对象实例 fso = new ActiveXObject("Scripting.FileSystemObject"); // 获取Drive 对象 fldr = fso.GetFolder("c:\\"); // 显示父目录名称 alert("Parent folder name is: " + fldr + "\n"); // 显示所在drive名称 alert("Contained on drive " + fldr.Drive + "\n"); // 判断是否为根目录 if (fldr.IsRootFolder) alert("This is the root folder."); else alert("This folder isn't a root folder."); alert("\n\n"); // 创建新文件夹 fso.CreateFolder ("C:\\Bogus"); alert("Created folder C:\\Bogus" + "\n"); // 显示文件夹基础名称,不包含路径名 alert("Basename = " + fso.GetBaseName("c:\\bogus") + "\n"); // 删除创建的文件夹 fso.DeleteFolder ("C:\\Bogus"); alert("Deleted folder C:\\Bogus" + "\n"); 五、操作文件(Files) 对文件进行的操作要比以上介绍的驱动器(Drive)和文件夹(Folder)操作复杂些,基本上分为以下两个类别:对文件的创建、拷贝、移动、删除操作和对文件内容的创建、添加、删除和读取操作。下面分别详细介绍。 (一)创建文件 一共有3种方法可用于创建一个空文本文件,这种文件有时候也叫做文本流(text stream)。 第一种是使用CreateTextFile方法。代码如下: var fso, f1; fso = new ActiveXObject("Scripting.FileSystemObject"); f1 = fso.CreateTextFile("c:\\testfile.txt", true); 第二种是使用OpenTextFile方法,并添加上ForWriting属性,ForWriting的值为2。代码如下: var fso, ts; var ForWriting= 2; fso = new ActiveXObject("Scripting.FileSystemObject"); ts = fso.OpenTextFile("c:\\test.txt", ForWriting, true); 第三种是使用OpenAsTextStream方法,同样要设置好ForWriting属性。代码如下: var fso, f1, ts; var ForWriting = 2; fso = new ActiveXObject("Scripting.FileSystemObject"); fso.CreateTextFile ("c:\\test1.txt"); f1 = fso.GetFile("c:\\test1.txt"); ts = f1.OpenAsTextStream(ForWriting, true); (二)添加数据到文件 当文件被创建后,一般要按照“打开文件->填写数据->关闭文件”的步骤实现添加数据到文件的目的。 打开文件可使用FileSystemObject对象的OpenTextFile方法,或者使用File对象的OpenAsTextStream方法。 填写数据要使用到TextStream对象的Write、WriteLine或者WriteBlankLines方法。在同是实现写入数据的功能下,这3者的区别在于:Write方法不在写入数据末尾添加新换行符,WriteLine方法要在最后添加一个新换行符,而WriteBlankLines则增加一个或者多个空行。 关闭文件可使用TextStream对象的Close方法。 (三)创建文件及添加数据例程 下面的代码将创建文件、添加数据、关闭文件几个步骤结合起来进行应用: var fso, tf; fso = new ActiveXObject("Scripting.FileSystemObject"); // 创建新文件 tf = fso.CreateTextFile("c:\\testfile.txt", true); // 填写数据,并增加换行符 tf.WriteLine("Testing 1, 2, 3.") ; // 增加3个空行 tf.WriteBlankLines(3) ; // 填写一行,不带换行符 tf.Write ("This is a test."); // 关闭文件 tf.Close(); (四)读取文件内容 从文本文件中读取数据要使用TextStream对象的Read、ReadLine或ReadAll 方法。Read方法用于读取文件中指定数量的字符; ReadLine方法读取一整行,但不包括换行符;ReadAll方法则读取文本文件的整个内容。读取的内容存放于字符串变量中,用于显示、分析。 方法或者属性 描述 BuildPath() 生成一个文件路径 CopyFile() 复制文件 CopyFolder() 复制目录 CreateFolder() 创建新目录 CreateTextFile() 生成一个文件 DeleteFile() 删除一个文件 DeleteFolder() 删除一个目录 DriveExists() 检验盘符是否存在 Drives 返回盘符的集合 FileExists() 检验文件是否存在 FolderExists 检验一个目录是否存在 GetAbsolutePathName() 取得一个文件的绝对路径 GetBaseName() 取得文件名 GetDrive() 取得盘符名 GetDriveName() 取得盘符名 GetExtensionName() 取得文件的后缀 GetFile() 生成文件对象 GetFileName() 取得文件名 GetFolder() 取得目录对象 GetParentFolderName 取得文件或目录的父目录名 GetSpecialFolder() 取得特殊的目录名 GetTempName() 生成一个临时文件对象 MoveFile() 移动文件 MoveFolder() 移动目录 OpenTextFile() 打开一个文件流 f.Files //目录下所有文件集合 f.attributes //文件属性 Case 0 Str="普通文件。没有设置任何属性。 " Case 1 Str="只读文件。可读写。 " Case 2 Str="隐藏文件。可读写。 " Case 4 Str="系统文件。可读写。 " Case 16 Str="文件夹或目录。只读。 " Case 32 Str="上次备份后已更改的文件。可读写。 " Case 1024 Str="链接或快捷方式。只读。 " Case 2048 Str=" 压缩文件。只读。" f.Datecreated // 创建时间 f.DateLastAccessed //上次访问时间 f.DateLastModified // 上次修改时间 f.Path //文件路径 f.Name //文件名称 f.Type //文件类型 f.Size // 文件大小(单位:字节) f.ParentFolder //父目录 f.RootFolder // 根目录

 

//获取当前文件目录下所有文件路径
searchFiles = function() {

	// alert("window.location.href:"+window.location.href);
	// alert("window.location:"+window.location);
	// alert("location.href:"+location.href);
	// alert("parent.location.href:"+parent.location.href);
	// alert("top.location.href:"+top.location.href);
	// alert("document.location.href:"+document.location.href);
	// alert("document.URL:"+document.URL);

	// 获取当前文件所在路径
	// 方法一
	// var str = location.href;
	// var arr = str.split("/");
	// delete arr[arr.length - 1];
	// var dir = arr.join("/");
	// alert(dir);

	// 获取当前文件所在路径
	// 方法二
	var path = document.URL;
	path = path.substr(0, path.lastIndexOf("\\") + 1);
	path = path.substr(path.indexOf("//") + 2, path.length);
	alert(path);

	var fso = new ActiveXObject("Scripting.FileSystemObject");

	var f = fso.GetFolder(path + "image\\");
	var fc = new Enumerator(f.files);
	// 以下内容是显示文件名
	for (; !fc.atEnd(); fc.moveNext()) {
		document.write(fc.item() + "<br>");
	}

	// 以下内容是显示目录名
	fk = new Enumerator(f.SubFolders);
	for (; !fk.atEnd(); fk.moveNext()) {
		document.write(fk.item() + "<br>");
	}
};

//BuildPath(路径,文件名)
//这个方法会对给定的路径加上文件,并自动加上分界符  
testBuildPath = function(path, filesName) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	var newpath = fso.BuildPath("c:\\tmp", "51js.txt"); // 生成 c:\tmp\51js.txt的路径
	alert(newpath);
};

// CopyFile(源文件, 目标文件, 覆盖)
// 复制源文件到目标文件,当覆盖值为true时,如果目标文件存在会把文件覆盖
testCopyFile = function(oldpath, newpath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	var newpath = fso.CopyFile("c:\\autoexec.bat", "d:\\autoexec.bak");
	alert(newpath);
};

// CopyFolder(对象目录,目标目录 ,覆盖)
// 复制对象目录到目标目录,当覆盖为true时,如果目标目录存在会把文件覆盖
testCopyFolder = function(oldpath, newpath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	fso.CopyFolder("c:\\WINDOWS\\Desktop", "d:\\"); // 把C盘的Desktop目录复制到D盘的根目录
};

// CreateFolder(目录名)
// 创建一个新的目录
testCopyFolder = function(newpath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	var newFolderName = fso.CreateFolder("c:\\51JS"); // 在C盘上创建一个51JS的目录
	alert(newFolderName);
};

// CreateTextFile(文件名, 覆盖)
// 创建一个新的文件,如果此文件已经存在,你需要把覆盖值定为true
testCreateTextFile = function(oldpath, newpath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	// 脚本将在C盘创建一个叫autoexec51JS.bat的文件
	var newFileObject = fso.CreateTextFile("c:\\autoexec51JS.bat", true);
	alert(newFileObject);
};

// DeleteFile(文件名, 只读?)
// 删除一个文件,如果文件的属性是只读的话,你需要把只读值设为true
testDeleteFile = function(oldpath, newpath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	// 为了安全我先把要删除的autoexec.bat备份到你的D盘
	var newpath = fso.CopyFile("c:\\autoexec.bat", "d:\\autoexec.bat");
	alert(newpath);
	// 把C盘的autoexec.bat文件删除掉
	fso.DeleteFile("c:\\autoexec.bat", true);
};

// DeleteFolder(文件名, 只读?)
// 删除一个目录,如果目录的属性是只读的话,你需要把只读值设为true
testDeleteFolder = function(oldpath, newpath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	// 为了安全我先把你C盘的Desktop目录复制到你D盘的根目录
	fso.CopyFolder("c:\\WINDOWS\\Desktop", "d:\\");
	// 把你的Desktop目录删除,但因为desktop是系统的东西,所以不能全部删除,但.........
	fso.DeleteFolder("c:\\WINDOWS\\Desktop", true);
};

// DriveExists(盘符)
// 检查一个盘是否存在,如果存在就返会真,不存在就返回.......
testDriveExists = function(diskDrive) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	hasDriveD = fso.DriveExists("d"); // 检查系统是否有D盘存在
	hasDriveZ = fso.DriveExists("z"); // 检查系统是否有Z盘存在
	if (hasDriveD)
		alert("你的系统内有一个D盘");
	if (!hasDriveZ)
		alert("你的系统内没有Z盘");
};

// FileExists(文件名)
// 检查一个文件是否存在,如果存在就返会真,不存在就返回.......
testFileExists = function(filePath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	fileName = fso.FileExists("c:\\autoexec.bat");
	if (fileName)
		alert("你在C盘中有autoexec.bat文件,按下确定后这个文件将被删除!"); // 开个玩笑:)
};

// FolderExists(目录名)
// 检查一个目录是否存在,如果存在就返会真,不存在就返回.......
testFolderExists = function(folderPath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	folderName = fso.FolderExists("c:\\WINDOWS\\Fonts");
	if (folderName)
		alert("按下确定后系统的字库将被删除!"); // 开个玩笑:)
};

// GetAbsolutePathName(文件对象)
// 返回文件对象在系统的绝对路径
testGetAbsolutePathName = function(filePath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	pathName = fso.GetAbsolutePathName("c:\\autoexec.bat");
	alert(pathName);
};

// GetBaseName(文件对象)
// 返回文件对象的文件名
testGetBaseName = function(filePath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	baseName = fso.GetBaseName("c:\\autoexec.bat"); // 取得autoexec.bat的文件名autoexec
	alert(baseName);
};

// GetExtensionName(文件对象)
// 文件的后缀
testGetExtensionName = function(filePath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	exName = fso.GetExtensionName("c:\\autoexec.bat"); // 取得autoexec.bat后缀bat
	alert(exName);
};

// GetParentFolderName(文件对象)
// 取得父级的目录名
testGetParentFolderName = function(filePath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	parentName = fso.GetParentFolderName("c:\\autoexec.bat"); // 取得autoexec.bat的父级目录C盘
	alert(parentName);
};

// GetSpecialFolder(目录代码)
// 取得系统中一些特别的目录的路径,目录代码有3个分别是 0:安装Window的目录 1:系统文件目录 2:临时文件目录
testGetSpecialFolder = function(code) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	tmpFolder = fso.GetSpecialFolder(2); // 取得系统临时文件目录的路径 如我的是
	// C:\windows\temp
	alert(tmpFolder);
};

// GetTempName()
// 生成一个随机的临时文件对象,会以rad带头后面跟着些随机数,就好象一些软件在安装时会生成*.tmp
testGetSpecialFolder = function() {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	tmpName = fso.GetTempName(); // 我在测试时就生成了radDB70E.tmp
	alert(tmpName);
};

// MoveFile(源文件, 目标文件)
// 把源文件移到目标文件的位置
testMoveFile = function(oldpath, newpath) {
	var fso = new ActiveXObject("Scripting.FileSystemObject");
	var newpath = fso.MoveFile("c:\\autoexec.bat", "d:\\autoexec.bat"); // 把C盘的autoexec.bat文件移移动到D盘
	alert(newpath);
};
分享到:
评论
1 楼 sessionsong 2013-12-21  
学习了!O(∩_∩)O谢谢

相关推荐

    通过js获取本地文件夹中的文件列表

    让我们深入探讨如何利用这些技术来实现“通过js获取本地文件夹中的文件列表”。 首先,我们要明确的是,JavaScript无法直接遍历本地目录,除非在特定的沙盒环境中,如使用Chrome的实验性File System Access API。这...

    javascript文件中获取当前文件路径

    在开发javascript插件的过程中,我们有时候需要获取当前JS文件的路径,用于自动加载一些图片、CSS等外部资源,但是javascript文件中并没有像PHP那样的__FILE__常量来供我们取得当前文件路径

    Javascript如何遍历一个文件夹下的所有文件与目录

    在JavaScript中,遍历文件夹下的所有文件与目录是一项常见的任务,尤其是在需要处理本地文件系统时。本文将详细介绍如何使用`Scripting.FileSystemObject`对象来实现这一功能,并对提供的示例代码进行深入解析。 ##...

    Html读取本地文件夹下图片并显示的示例代码

    在Html上选择本地文件夹,自动读取文件夹及子文件夹下的所有图片并显示在页面。 技术分析: 存在问题 Html中file标签获取到的路径时相对的。 Html中Img指定源时需要的是绝对路径。 解决方法: 调用Web API接口...

    使用JavaScript实现一个本地文件选择器功能

    在JavaScript中实现一个本地文件选择器功能,是前端开发中常见的需求,这通常涉及到HTML5的File API。这个功能允许用户从他们的计算机上选择文件,并且可以进行预览、上传或者其他处理。以下将详细讲解如何实现这个...

    在html页面使用JavaScript实行文件上传到本地服务器并获取文件所在路径

    使用JavaScript实现文件上传到本地服务器并获取到上传后文件所在路径,是由到JavaScript,java以及html页面。这个比较好,不是在jsp上获取路径,jsp太简单了,而且过时了,所以就在html页面实现了下功能,我主要是做...

    js 浏览本地文件夹系统示例代码

    然而,通过ActiveXObject,这个仅在Internet Explorer中可用的功能,我们可以实现一些特定的本地系统交互,如浏览和选择本地文件夹。在给定的代码示例中,`BrowseFolder()`函数就是用来实现这个功能。 首先,让我们...

    javascript读取本地文件和目录方法详解

    比如,对文件和文件夹进行读、写和删除,就象在VB、VC等高级语言中经常做的工作一样。怎么样,你是否需要了解这方面的知识?那就请跟我来,本文将详细描述如何使用Javascript语言进行文件操作。 一、功能实现核心:...

    javascript获取浏览器临时目录

    然而,由于浏览器安全策略的限制,JavaScript直接获取本地文件系统路径的能力受到严格限制。本文将详细介绍如何在不同浏览器环境中通过JavaScript获取浏览器临时目录的方法。 #### 二、背景知识 1. **浏览器安全...

    Javascript如何递归遍历本地文件夹

    在JavaScript中,递归遍历本地文件夹通常用于获取文件系统中的文件信息,例如文件路径、文件名和最后修改时间等。以下是如何使用JavaScript实现这一功能的详细解释: 首先,我们要明白JavaScript本身并不具备直接...

    java查询本地文件夹动态显示并下载文件

    8. 用户界面:前端页面通常使用HTML、CSS和JavaScript构建,可以使用AJAX与后端交互,动态获取和显示文件列表,处理文件下载事件。 9. 错误处理:添加异常处理机制,捕获并处理文件不存在、无权限等可能出现的错误...

    通过JavaScript下载文件到本地的方法(单文件)

    ### 通过JavaScript下载文件到本地的方法(单文件) #### 知识点一:同源文件下载 在开发中,对于同源的文件,我们可以利用HTML `&lt;a&gt;` 标签的 `download` 属性来实现文件的下载功能。`download` 属性指示浏览器下载...

    javascript读取文件夹中的文件并输出

    在JavaScript中,读取文件夹中的文件并输出是一项常见的任务,尤其在开发Web应用程序时。JavaScript作为客户端脚本语言,通常不能直接访问本地文件系统,因为出于安全原因,浏览器会限制这种权限。但是,借助HTML5...

    js获取文件里面的所有文件名(实例)

    在JavaScript中,获取文件或文件夹的信息通常涉及到与操作系统交互,这在客户端JavaScript中是有限制的,因为出于安全原因,浏览器不允许直接访问用户的文件系统。然而,在Internet Explorer中,可以使用...

    JQuery实现本地文件的读取、文件内容的复制

    本文将深入探讨如何使用jQuery实现本地文件的读取和文件内容的复制,这对于网页应用中的数据导入、导出或者用户交互功能非常重要。 首先,我们需要明白jQuery本身并不直接支持文件系统的操作,因为它主要是为浏览器...

    html js 遍历一个文件夹里的指定类型的所有文件,查找文件夹中所有的html文件并可读取内容

    首先,JavaScript本身并不直接支持访问用户的本地文件系统,因为出于安全考虑,浏览器有沙盒机制限制了JavaScript的权限。但是,通过HTML5引入的File API,我们可以获得一定的文件访问能力。在用户许可的情况下,...

    javascript 实现的文件拷贝(能够循环遍历所选文件夹)

    获取文件列表后,可以进一步处理这些文件。 2. **读取文件内容**:使用`FileReader`对象的`readAsDataURL()`方法读取文件内容。这个方法会返回一个包含文件数据的data URL,可以用在内存中表示文件。 ```...

    nodejs实现获取本地文件夹下图片信息功能示例

    在Node.js环境中,获取本地文件夹下的图片信息是一项常见的任务,尤其在开发Web应用时,可能需要处理大量的静态资源,如图片。本示例详细介绍了如何利用Node.js的内置模块和第三方库来实现这一功能。 首先,我们...

    nodejs实现读取本地文件生成目录树

    在Node.js环境中,读取本地文件并生成目录树是一种常见的需求,特别是在开发文件管理系统或进行文件操作时。Node.js提供了一系列强大的文件系统(fs)模块,使得开发者能够方便地进行文件和目录的操作。本篇文章将...

Global site tag (gtag.js) - Google Analytics