`
lujar
  • 浏览: 515189 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

JavaScript高级应用:文件操作篇

    博客分类:
  • Web
阅读更多
Javascript是网页制作中离不开的脚本语言,依靠它,一个网页的内容才生动活泼、富有朝气。但也许你还没有发现并应用它的一些更高级的功能吧?比如,对文件和文件夹进行读、写和删除,就象在VB、VC等高级语言中经常做的工作一样。怎么样,你是否需要了解这方面的知识?那就请跟我来,本文将详细描述如何使用Javascript语言进行文件操作。

一、功能实现核心:FileSystemObject 对象

其实,要在Javascript中实现文件操作功能,主要就是依靠FileSystemobject对象。在详细介绍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对象的相关属性和方法列表

(二)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方法则读取文本文件的整个内容。读取的内容存放于字符串变量中,用于显示、分析。在使用Read或ReadLine方法读取文件内容时,如果要跳过一些部分,就要用到Skip或SkipLine方法。

下面的代码演示打开文件、填写数据,然后读取数据:

var fso, f1, ts, s;

var ForReading = 1;

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

// 创建文件

f1 = fso.CreateTextFile("c:\\testfile.txt", true);

// 填写一行数据

f1.WriteLine("Hello World");

f1.WriteBlankLines(1);

// 关闭文件

f1.Close();

// 打开文件

ts = fso.OpenTextFile("c:\\testfile.txt", ForReading);

// 读取文件一行内容到字符串

s = ts.ReadLine();

// 显示字符串信息

alert("File contents = '" + s + "'");

// 关闭文件

ts.Close();

(五)移动、拷贝和删除文件

对于以上三种文件操作,Javascript各有两种对应的方法:File.Move 或 FileSystemObject.MoveFile用于移动文件;File.Copy 或 FileSystemObject.CopyFile用于拷贝文件;File.Delete 或 FileSystemObject.DeleteFile用于删除文件。

下面的代码演示在驱动器C的根目录下创建一个文本文件,填写一些内容,然后将文件移动到\tmp目录下,再在目录\temp下面建立一个文件拷贝,最后删除这两个目录的文件:

var fso, f1, f2, s;

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

f1 = fso.CreateTextFile("c:\\testfile.txt", true);

// 写一行

f1.Write("This is a test.");

// 关闭文件

f1.Close();

// 获取C:\根目录下的文件句柄

f2 = fso.GetFile("c:\\testfile.txt");

// 移动文件到\tmp目录下

f2.Move ("c:\\tmp\\testfile.txt");

// 拷贝文件到\temp目录下

f2.Copy ("c:\\temp\\testfile.txt");

// 获取文件句柄

f2 = fso.GetFile("c:\\tmp\\testfile.txt");

f3 = fso.GetFile("c:\\temp\\testfile.txt");

// 删除文件

f2.Delete();

f3.Delete();

六、结 语

通过以上对FileSystemObject的各种对象、属性和方法的介绍和示例,相信你已经对如何使用JavaScript语言在页面中操作驱动器、文件和文件夹有了清晰的认识。但是上述提及的例程都非常简单,要全面、灵活地掌握JavaScript文件操作技术,还需要大量的实践练习。而且还有一点提醒大家,由于涉及到在浏览器中进行文件读写这样的高级操作,对于默认的浏览器安全级别而言,在代码运行前都会有一个信息提示,这点请在实际环境中提示访问者注意。
分享到:
评论

相关推荐

    JavaScript高级应用:文件操作篇.doc

    总结来说,JavaScript的高级应用之一就是文件操作,通过`FileSystemObject`对象,开发者可以在网页环境中实现类似桌面应用程序的文件管理功能,尽管这些功能通常受限于特定的浏览器环境和安全设置。了解和掌握这些...

    Javascript高级应用与实践.pdf

    不过,根据文件标题“Javascript高级应用与实践.pdf”,我们可以推测文档内容大致会涉及以下几个方面,尽管具体的细节无法得知: 1. JavaScript基础知识回顾:JavaScript是前端开发中最为核心的技术之一,文档可能...

    JavaScript高级应用与实践PDF版本下载.txt

    根据提供的文件信息,本文将对《JavaScript高级应用与实践》这一主题进行深入解析,并提炼出相关的知识点。尽管提供的链接可以直接获取到PDF版本的资源,但为了更好地理解和掌握书中的核心内容,下面将从多个角度来...

    javaScript高级编程

    JavaScript是一种广泛使用的脚本语言,...JavaScript高级编程是一本全面介绍JavaScript语言的书,尤其适合初学者,通过这本书的学习,可以为Web开发打下坚实的基础,理解并运用JavaScript来增强网页的交互性和功能性。

    Javascript文件操作教程

    Javascript是网页制作中离不开的脚本语言,依靠它,一个网页的内容才生动活泼、富有朝气。但也许你还没有发现并应用它的一些更高级的功能吧?...那就请跟我来,本文将详细描述如何使用Javascript语言进行文件操作。

    javascript高级程序设计

    这只是JavaScript高级程序设计中的一部分内容,书中还涵盖了函数、对象、数组、正则表达式、错误处理、DOM操作、BOM(浏览器对象模型)以及异步编程等更深入的主题。通过学习这些内容,读者可以全面掌握JavaScript,...

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

    那就请跟我来,本文将详细描述如何使用Javascript语言进行文件操作。 一、功能实现核心:FileSystemObject 对象 其实,要在Javascript中实现文件操作功能,主要就是依靠FileSystemobject对象。在详细介绍...

    Javascript高级教程

    "JavaScript高级教程"很可能还包括DOM(文档对象模型)操作,这是JavaScript与HTML页面交互的主要方式。开发者可以使用JavaScript来动态修改网页内容、添加事件监听器,以及创建复杂的用户交互。 最后,随着Web开发...

    JavaScript高级_javascript_zip_

    在本压缩包文件"JavaScript高级_javascript_zip_"中,可能包含了关于JavaScript高级主题的详细教程或课程资料,特别是"day10_JavaScript高级"这一子文件,可能是该系列学习的第十天内容,集中讲解了一些核心的高级...

    XMPP高级编程+使用JavaScript和jQuery

    本篇内容将深入探讨XMPP高级编程,以及如何结合JavaScript和jQuery来实现Web IM(即时通讯)功能。 一、XMPP协议基础 XMPP最初由Jabber项目开发,后来成为互联网工程任务组(IETF)的标准。它的核心特性是基于XML的...

    javascript高级教程

    【JavaScript高级教程】是一份深度探讨JavaScript编程语言的资源,主要针对有志于提升JavaScript技能的开发者。这份教程可能包含了JavaScript的核心概念、高级特性以及实际应用的实例,旨在帮助学习者掌握JavaScript...

    javascript实例应用---游戏类.rar

    在这个“javascript实例应用---游戏类.rar”压缩包中,我们很可能会找到一系列利用JavaScript实现的游戏示例,这些示例可以涵盖从基础到高级的各种游戏开发技术。 JavaScript在游戏开发中的应用主要包括以下几个...

    JavaScript 异步编程:基本指南.docx

    本文将深入讲解JavaScript异步编程的基础和高级概念,帮助开发者理解并掌握这一核心技能。 1. **异步编程的基本概念** 在JavaScript中,异步编程意味着某些操作不会阻塞程序的执行,而是以非阻塞的方式进行。这是...

    javascript 高级程序设计

    标题与描述中的“JavaScript高级程序设计”指向了一种深度探讨JavaScript语言及其在Web开发中高级应用的教程或书籍。它旨在超越基础知识,探索更复杂的概念和技术,适合已经掌握JavaScript基础并希望进一步提升技能...

    javascript文件查找

    ### JavaScript 文件查找与本地文件操作 #### 一、概述 在网页开发中,JavaScript 是一种不可或缺的脚本语言,能够使网页内容更加生动有趣。除了常见的网页交互功能外,JavaScript 还可以实现对本地文件系统的操作...

    ArcGIS JavaScript API开发文档—高级篇

    ArcGIS JavaScript API开发文档—高级篇是Esri中国为有一定基础的开发人员提供的高级开发指导文档,它详细介绍了在开发ArcGIS相关应用时所需要注意的高级功能和技巧。本文将基于提供的文件内容,梳理和阐述一些关键...

    W3C JavaScript 高级教程

    此外,`W3C JavaScript 高级教程.chm`可能是该教程的电子版,通常`.chm`文件是Windows的帮助文件格式,包含了丰富的文本、链接和索引,方便用户查阅。`阅读器下载.htm`可能是提供帮助文件阅读器下载的链接,确保用户...

    JAVAScript的早餐:在咖啡桌上解决掉你的问题.rar

    8. **表单插件与库**:有许多成熟的JavaScript库,如jQuery Form Plugin、Vue.js的表单绑定等,提供了更高级的表单处理功能,如自动验证、进度条显示、文件上传预览等,简化开发工作。 9. **表单序列化与JSON**:在...

    javascript高级教程2.txt

    根据提供的文件信息,我们可以推断出这是一篇关于JavaScript高级应用的文章或教程。尽管原文存在大量乱码,但我们可以从可识别的部分提炼出关键知识点。接下来,将详细阐述这些知识点。 ### JavaScript高级教程概览...

    javascript高级教程 pdf,学javascript必读

    这篇“JavaScript高级教程”针对想要深入理解和提升JavaScript技能的开发者,无论你是初学者还是有一定经验的程序员,都能从中受益匪浅。 JavaScript的核心概念包括变量、数据类型、操作符、流程控制(如条件语句和...

Global site tag (gtag.js) - Google Analytics