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


Posted in Javascript onAugust 06, 2020

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读取本地文件和目录方法详解的文章就介绍到这了,更多相关javascript读取本地文件和目录内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
jQuery 1.4 15个你应该知道的新特性(译)
Jan 24 Javascript
JavaScript高级程序设计 读书笔记之十 本地对象Date日期
Feb 27 Javascript
JS中setTimeout()的用法详解
Apr 14 Javascript
使用js如何实现全选与全不选
Dec 30 Javascript
js实现页面a向页面b传参的方法
May 29 Javascript
JS+HTML5实现上传图片预览效果完整实例【测试可用】
Apr 20 Javascript
jQuery查找和过滤_动力节点节点Java学院整理
Jul 04 jQuery
原生JS实现小小的音乐播放器
Oct 16 Javascript
Vue使用watch监听一个对象中的属性的实现方法
May 10 Javascript
RxJS的入门指引和初步应用
Jun 15 Javascript
vue实现鼠标经过动画
Oct 16 Javascript
使用 Vue-TCB 快速在 Vue 应用中接入云开发的方法
Feb 10 Javascript
antd vue 刷新保留当前页面路由,保留选中菜单,保留menu选中操作
Aug 06 #Javascript
javascript实现页面的实时时钟显示示例
Aug 06 #Javascript
Javascript如何递归遍历本地文件夹
Aug 06 #Javascript
通过vue刷新左侧菜单栏操作
Aug 06 #Javascript
Vue页面手动刷新,实现导航栏激活项还原到初始状态
Aug 06 #Javascript
浅谈JavaScript中等号、双等号、 三等号的区别
Aug 06 #Javascript
前端开发基础javaScript的六大作用
Aug 06 #Javascript
You might like
ajax缓存问题解决途径
2006/12/06 PHP
PHP防注入安全代码
2008/04/09 PHP
PHP 页面编码声明方法详解(header或meta)
2010/03/12 PHP
PHP加Nginx实现动态裁剪图片方案
2014/03/10 PHP
php实现utf-8转unicode函数分享
2015/01/06 PHP
php截取指定2个字符之间字符串的方法
2015/04/15 PHP
详解 PHP加密解密字符串函数附源码下载
2015/12/18 PHP
php结合md5实现的加密解密方法
2016/01/25 PHP
PHP编写文件多服务器同步程序
2016/07/02 PHP
yii2控制器Controller Ajax操作示例
2016/07/23 PHP
innertext , insertadjacentelement , insertadjacenthtml , insertadjacenttext 等区别
2007/06/29 Javascript
autoPlay 基于jquery的图片自动播放效果
2011/12/07 Javascript
jQuery选择id属性带有点符号元素的方法
2015/03/17 Javascript
基于javascript实现tab切换特效
2016/03/29 Javascript
Nodejs读取文件时相对路径的正确写法(使用fs模块)
2017/04/27 NodeJs
Bootstrap Multiselect 常用组件实现代码
2017/07/09 Javascript
解决ie11 SCRIPT5011:不能执行已释放Script的代码问题
2019/05/05 Javascript
如何测量vue应用运行时的性能
2019/06/21 Javascript
vue项目创建步骤及路由router
2020/01/14 Javascript
绘制微信小程序验证码功能的实例代码
2021/01/05 Javascript
python如何定义带参数的装饰器
2018/03/20 Python
Python爬虫获取图片并下载保存至本地的实例
2018/06/01 Python
Python定时任务工具之APScheduler使用方式
2019/07/24 Python
Ranorex通过Python将报告发送到邮箱的方法
2020/01/12 Python
解决tensorflow添加ptb库的问题
2020/02/10 Python
python网络编程:socketserver的基本使用方法实例分析
2020/04/09 Python
HTML5不支持标签和新增标签详解
2016/06/27 HTML / CSS
ProBikeKit德国:在线公路自行车专家
2018/06/03 全球购物
建筑工程专业学生的自我评价
2013/12/25 职场文书
狼和鹿教学反思
2014/02/05 职场文书
安全生产专项整治方案
2014/05/06 职场文书
建设办主任四风问题整改思路和措施
2014/09/20 职场文书
2015廉洁自律个人总结
2015/02/14 职场文书
大学生团员个人总结
2015/02/14 职场文书
2015年公司后勤管理工作总结
2015/05/13 职场文书
哈姆雷特读书笔记
2015/06/29 职场文书