求chrome 浏览器下用javascript读写txt文件的办法!
web程序不要妄想对客户机的文件进行读写。ActiveXObject是IE特有的。这种东西本身就是不安全的,现在不允许,今后更不会允许。
假设我做一网站,你来访问,访问了之后我直接在你的磁盘上写上1亿个垃圾txt文件,你咋想?所以不要考虑这个了。读写文件是针对服务器的。
思路
采用jquery的ajax方式进行文件信息读取
代码
<html><head>
<script type="text/javascript" src="/jquery/jqueryjs"></script>
<script type="text/javascript">
$(document)ready(function(){
$("#b01")click(function(){
htmlobj=$ajax({url:"/jquery/test1txt",async:false});
$("#myDiv")html(htmlobjresponseText);
});
});
</script>
</head>
<body>
<div id="myDiv"><h2>通过 AJAX 改变文本</h2></div>
<button id="b01" type="button">改变内容</button>
</body>
</html>
js获取本地文件夹下的文件
一、功能实现核心:FileSystemObject 对象
要在javascript中实现文件操作功能,主要就是依靠FileSystemobject对象。
二、FileSystemObject编程
使用FileSystemObject 对象进行编程很简单,一般要经过如下的步骤: 创建FileSystemObject对象、应用相关方法、访问对象相关属性 。
(一)创建FileSystemObject对象
创建FileSystemObject对象的
代码只要1行:
var fso = new ActiveXObject("ScriptingFileSystemObject");上述代码执行后,fso就成为一个FileSystemObject对象实例。
(二)应用相关方法
创建对象实例后,就可以使用对象的相关方法了。比如,使用CreateTextFile方法创建一个文本文件:
var fso = new ActiveXObject("ScriptingFileSystemObject");var f1 = fsocreatetextfile("c:\myjstesttxt",true");
(三)访问对象相关属性
要访问对象的相关属性,首先要建立指向对象的句柄,这就要通过get系列方法实现:GetDrive负责获取驱动器信息,GetFolder负责获取文件夹信息,GetFile负责获取文件信息。比如,指向下面的代码后,f1就成为指向文件c: esttxt的句柄:
var fso = new ActiveXObject("ScriptingFileSystemObject");var f1 = fsoGetFile("c:\myjstesttxt");
然后,使用f1访问对象的相关属性。比如:
var fso = new ActiveXObject("ScriptingFileSystemObject");var f1 = fsoGetFile("c:\myjstesttxt");
alert("File last modified: " + f1DateLastModified);
执行上面最后一句后,将显示c:myjstesttxt的最后修改日期属性值。
但有一点请注意:对于使用create方法建立的对象,就不必再使用get方法获取对象句柄了,这时直接使用create方法建立的句柄名称就可以:
var fso = new ActiveXObject("ScriptingFileSystemObject");var f1 = fsocreatetextfile("c:\myjstesttxt",true");
alert("File last modified: " + f1DateLastModified);
三、操作驱动器(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("ScriptingFileSystemObject");
drv = fsoGetDrive(fsoGetDriveName("c:\"));
s += "Drive C:" + " - ";
s += drvVolumeName + " ";
s += "Total Space: " + drvTotalSize / 1024;
s += " Kb" + " ";
s += "Free Space: " + drvFreeSpace / 1024;
s += " Kb" + " ";
alert(s);
四、操作文件夹(Folders)
涉及到文件夹的操作包括创建、移动、删除以及获取相关属性。
Folder对象操作例程 :
下面的例程将练习获取父文件夹名称、创建文件夹、删除文件夹、判断是否为根目录等操作:
var fso, fldr, s = "";
// 创建FileSystemObject对象实例
var fso, fldr, s = "";
// 创建FileSystemObject对象实例
fso = new ActiveXObject("ScriptingFileSystemObject");
// 获取Drive 对象
fldr = fsoGetFolder("c:\");
// 显示父目录名称
alert("Parent folder name is: " + fldr + " ");
// 显示所在drive名称
alert("Contained on drive " + fldrDrive + " ");
// 判断是否为根目录
if (fldrIsRootFolder)
alert("This is the root folder");
else
alert("This folder isn't a root folder");
alert(" ");
// 创建新文件夹
fsoCreateFolder ("C:\Bogus");
alert("Created folder C:\Bogus" + " ");
// 显示文件夹基础名称,不包含路径名
alert("Basename = " + fsoGetBaseName("c:\bogus") + " ");
// 删除创建的文件夹
fsoDeleteFolder ("C:\Bogus");
alert("Deleted folder C:\Bogus" + " ");
五、操作文件(Files)
对文件进行的操作要比以上介绍的驱动器(Drive)和文件夹(Folder)操作复杂些,基本上分为以下两个类别:对文件的创建、拷贝、移动、删除操作和对文件内容的创建、添加、删除和读取操作。下面分别详细介绍。
(一)创建文件
一共有3种方法可用于创建一个空文本文件,这种文件有时候也叫做文本流(text stream)。
第一种是使用CreateTextFile方法。代码如下:
var fso, f1;
fso = new ActiveXObject("ScriptingFileSystemObject");
f1 = fsoCreateTextFile("c:\testfiletxt", true);
第二种是使用OpenTextFile方法,并添加上ForWriting属性,ForWriting的值为2。代码如下:
var fso, ts;
var ForWriting= 2;
fso = new ActiveXObject("ScriptingFileSystemObject");
ts = fsoOpenTextFile("c:\testtxt", ForWriting, true);
第三种是使用OpenAsTextStream方法,同样要设置好ForWriting属性。代码如下:
var fso, f1, ts;
var ForWriting = 2;
fso = new ActiveXObject("ScriptingFileSystemObject");
fsoCreateTextFile ("c:\test1txt");
f1 = fsoGetFile("c:\test1txt");
ts = f1OpenAsTextStream(ForWriting, true);
(二)添加数据到文件
当文件被创建后,一般要按照“打开文件->填写数据->关闭文件”的步骤实现添加数据到文件的目的。
打开文件可使用FileSystemObject对象的OpenTextFile方法,或者使用File对象的OpenAsTextStream方法。
填写数据要使用到TextStream对象的Write、WriteLine或者WriteBlankLines方法。在同是实现写入数据的功能下,这3者的区别在于:Write方法不在写入数据末尾添加新换行符,WriteLine方法要在最后添加一个新换行符,而WriteBlankLines则增加一个或者多个空行。
关闭文件可使用TextStream对象的Close方法。
(三)创建文件及添加数据例程
下面的代码将创建文件、添加数据、关闭文件几个步骤结合起来进行应用:
var fso, tf;
fso = new ActiveXObject("ScriptingFileSystemObject");
// 创建新文件
tf = fsoCreateTextFile("c:\testfiletxt", true);
// 填写数据,并增加换行符
tfWriteLine("Testing 1, 2, 3") ;
// 增加3个空行
tfWriteBlankLines(3) ;
// 填写一行,不带换行符
tfWrite ("This is a test");
// 关闭文件
tfClose();
(四)读取文件内容
从文本文件中读取数据要使用TextStream对象的Read、ReadLine或ReadAll 方法。Read方法用于读取文件中指定数量的字符; ReadLine方法读取一整行,但不包括换行符;ReadAll方法则读取文本文件的整个内容。读取的内容存放于字符串变量中,用于显示、分析。
把你的这个txt文件,改成json文件(js也可以);
你可以做一个测试,将你的json文件和你的调用js文件和你的页面放在一个目录下;然后$getJSON(url, function(data){ // todo }); // 这里的url直接是xxjson
如果你的页面和js文件和json文件不再一个目录,就要将url写成页面相对于json文件的路径。
或者等等不一而足。
服务器推荐用nginx,配置简单,性能强悍。nginx可以使用代理访问后端的Nodejs应用服务器。配置方法:1)在配置文件http段内容添加后端服务器:http{#添加后端服务器,和nginx负载均衡配置一样upstreamnodejs{server127001:8080;}}2)给应用添加虚拟主机:server{listen80;server_nameIPlocation/{proxy_passnodejs;#名字和前面的对应,将所有的请求转发给后端的node}access_loglogs/nodejsaccesslogmain;#如果需要日志的话}推荐将静态文件如css、js和和应用服务器分开。
0条评论