On the Windows platform, JS can invoke many Windows provided ActiveXObject, this article uses JS to implement document processing, and use JS to write ActiveX to do a simple introduction.
Copy Code code as follows:
<! DOCTYPE HTML PUBLIC "-//w3c//dtd HTML 4.01 transitional//en" "HTTP://WWW.W3.ORG/TR/HTML4/LOOSE.DTD" >
<title> New Document </title>
<script type= "Text/javascript"
function Readfolder () {
var FilePath = "d:\\test\\";
var fso = new ActiveXObject ("Scripting.FileSystemObject"); //Load control
var f = fso. GetFolder (FilePath);
var underfiles = new Enumerator (f.files);//folder under File
for (;! Underfiles.atend (); Underfiles.movenext ()) {
var fn = "" + Underfiles.item ();
& nbsp; //alert (FN);
var content = ReadFile (FN,FSO);
Alert ( content);
}
}
Function ReadFile (PATH,FSO) {
var f1 = fso. GetFile (path);
var fh = fso. OpenTextFile (F1, 1/*reading*/);
var content = ';
while (!FH. AtEndOfStream) {
content = fh. ReadLine ();
}
fh.close ()
return content;
}
function Writeexcel () {
var excelapp = new ActiveXObject ("Excel.Application");
var excelsheet = new ActiveXObject ("Excel.Sheet");
ExcelSheet.Application.Visible = true;
ExcelSheet.ActiveSheet.Cells (1,1). Value = "This is column A, row 1";
Excelsheet.saveas ("D:\\test.") XLS ");
ExcelSheet.Application.Quit ();
}
</script>
<body>
<input type= "button" value= "Traverse Folder" onclick= "Readfolder ()" >
<input type= "button" value= "Write Excel" onclick= "Writeexcel ()" >
</body>
The ActiveXObject object in JavaScript is a reference that enables and returns a Automation object. How to use:
NEWOBJ = new ActiveXObject (servername.typename[, location])
The ActiveXObject object syntax has these parts: where the newobj is a required option. The name of the variable to assign to ActiveXObject.
ServerName is a required option. The name of the application that provided the object.
TypeName is a required option. The type or class of the object to create.
Location is optional. The name of the network server on which the object was created.
Remember: ActiveX is Microsoft's thing, so this thing only ie support!
Use ActiveXObject to create FileSystemObject action files in JavaScript
First, the function realizes the core: FileSystemObject object
To implement the file manipulation function in JavaScript, the main thing is to rely on the FileSystemObject object.
Second, FileSystemObject programming
Programming with a FileSystemObject object is simple, typically through the following steps: Creating FileSystemObject objects, applying related methods, and accessing object-related properties.
(i) Creating FileSystemObject objects
The code to create the FileSystemObject object takes only 1 lines:
var fso = new ActiveXObject ("Scripting.FileSystemObject");
After the above code executes, the FSO becomes a FileSystemObject object instance.
(ii) Application of relevant methodologies
After you create an object instance, you can use the associated methods of the object. For example, use the CreateTextFile method to create a text file:
var fso = new ActiveXObject ("Scripting.FileSystemObject");
var f1 = fso.createtextfile ("C:\\myjstest.txt", true);
(iii) Access to object-related properties
To access the related properties of an object, you first establish a handle to the object, which is done by the Get series method: Getdrive is responsible for obtaining the drive information, GetFolder is responsible for obtaining the folder information, GetFile is responsible for obtaining the file information. For example, after pointing to the following code, F1 becomes a handle to the file C:\test.txt:
var fso = new ActiveXObject ("Scripting.FileSystemObject");
var f1 = fso. GetFile ("C:\\myjstest.txt");
Then, use F1 to access the associated properties of the object. Like what:
Copy Code code as follows:
var fso = new ActiveXObject ("Scripting.FileSystemObject");
var f1 = fso. GetFile ("C:\\myjstest.txt");
Alert ("File Last modified:" + F1.) DateLastModified);
After the last sentence is executed, the last modified Date attribute value for C:\myjstest.txt is displayed.
But one thing. Note: For objects created using the Create method, you do not have to use the Get method to obtain the object handle, and then the handle name created directly by using the Create method can be:
Copy Code code as follows:
var fso = new ActiveXObject ("Scripting.FileSystemObject");
var f1 = fso.createtextfile ("C:\\myjstest.txt", true);
Alert ("File Last modified:" + F1.) DateLastModified);
Third, the operation of the driver (drives)
Using the FileSystemObject object to programmatically manipulate drives (drives) and folders (Folders) is easy, like interacting with files in a Windows file browser, such as copying, moving folders, and getting the properties of a folder.
(i) Drives object properties
The drive object is responsible for collecting the contents of the physical or logical drive resource in the system, which has the following properties:
L TotalSize: The drive size in bytes (byte).
L availablespace or FreeSpace: drive free space calculated in bytes (byte).
L DriveLetter: drive letter.
L DriveType: Drive type, value is: removable (mobile media), fixed (fixed media), Network (network Resource), CD-ROM, or RAM disk.
L SerialNumber: Serial code for the drive.
L FileSystem: The file system type of the drive on which the value is fat, FAT32, and NTFS.
L IsReady: The drive is available.
L ShareName: share name.
L VolumeName: Volume label name.
L Path and RootFolder: The path of the drive or the name of the root directory.
(ii) Drive object manipulation routines
The following routines show information such as the volume label, Total capacity, and free space of drive C:
Copy Code code as follows:
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);
Iv. Operation folder (Folders)
Actions that involve folders include creating, moving, deleting, and getting related properties.
Folder object Action routines:
The following routines practice getting the parent folder name, creating a folder, deleting a folder, and determining whether it is a root directory, and so on:
Copy Code code as follows:
var fso, fldr, S = "";
Create a FileSystemObject object instance
FSO = new ActiveXObject ("Scripting.FileSystemObject");
Get Drive Object
Fldr = fso. GetFolder ("c:\\");
Show Parent directory Name
Alert ("Parent folder name is:" + Fldr + "\ n");
Show Drive name
Alert ("contained on drive" + Fldr.) Drive + "\ n");
Determine if the root directory
if (Fldr. IsRootFolder)
Alert ("This is the root folder.");
Else
Alert ("This folder isn ' t a root folder.");
Alert ("\ n \ nthe");
Create a new Folder
Fso. CreateFolder ("C:\\bogus");
Alert ("Created folder C:\\bogus" + "\ n");
Displays the folder base name, not including the path name
Alert ("Basename =" + FSO.) Getbasename ("C:\\bogus") + "\ n");
Delete the Created folder
Fso. DeleteFolder ("C:\\bogus");
Alert ("Deleted folder C:\\bogus" + "\ n");
V. Operating documents (FILES)
Operations on files are more complex than the drives (Drive) and folders (folder) described above, and are essentially grouped into the following two categories: creation, copying, movement, deletion, and creation, addition, deletion, and reading of file content. The details are detailed below.
(i) Create a file
There are 3 ways to create an empty text file, which is sometimes called a text stream.
The first is the use of the CreateTextFile method. The code is as follows:
Copy Code code as follows:
var fso, F1;
FSO = new ActiveXObject ("Scripting.FileSystemObject");
F1 = fso. CreateTextFile ("C:\\testfile.txt", true);
The second is to use the OpenTextFile method and add the ForWriting property, the ForWriting value is 2. The code is as follows:
Copy Code code as follows:
var fso, TS;
var forwriting= 2;
FSO = new ActiveXObject ("Scripting.FileSystemObject");
TS = fso. OpenTextFile ("C:\\Test.txt", ForWriting, True);
The third is to use the OpenAsTextStream method, also set the ForWriting property.
Copy Code code as follows:
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);
(ii) Adding data to documents
When a file is created, you typically add data to a file by following the steps of "Open file-> fill data-> close file."
You can open a file by using the OpenTextFile method of the FileSystemObject object, or by using the OpenAsTextStream method of the file object.
Fill in the data to use the Write, WriteLine, or WriteBlankLines method of the TextStream object. The difference between these 3 is that the Write method does not add a new line break at the end of the write data, the WriteLine method adds a new newline character at the end, and WriteBlankLines adds one or more blank rows.
You can use the Close method of the TextStream object by closing the file.
(iii) Create files and add data routines
The following code combines several steps to create a file, add data, and close a file:
Copy Code code as follows:
var fso, TF;
FSO = new ActiveXObject ("Scripting.FileSystemObject");
Create a new file
tf = FSO. CreateTextFile ("C:\\testfile.txt", true);
Fill in the data and add line breaks
Tf. WriteLine ("Testing 1, 2, 3.");
Add 3 Blank Lines
Tf. WriteBlankLines (3);
Fill in a line without line breaks
Tf. Write ("This is a test.");
Close File
Tf. Close ();
(iv) Read the contents of the file
Reading data from a text file uses the read, ReadLine, or ReadAll method of the TextStream object. The Read method is used to read a specified number of characters in a file; the ReadLine method reads an entire line, but does not include a newline character; the ReadAll method reads the entire contents of the text file. The read content is stored in a string variable for display, parsing. When reading a file's contents using the Read or ReadLine method, skip or SkipLine method is used if you want to skip some parts.
The following code shows opening the file, filling in the data, and then reading the data:
Copy Code code as follows:
Var fso, F1, TS, s;
var ForReading = 1;
FSO = new ActiveXObject ("Scripting.FileSystemObject");
Create a file
F1 = fso. CreateTextFile ("C:\\testfile.txt", true);
Fill in one line of data
F1. WriteLine ("Hello World");
F1. WriteBlankLines (1);
Close File
F1. Close ();
Open File
TS = fso. OpenTextFile ("C:\\testfile.txt", ForReading);
Read a file line to a string
s = ts. ReadLine ();
Display string Information
Alert ("File contents = '" + S + "");
Close File
Ts. Close ();
(v) Moving, copying and deleting documents
For the above three file operations, JavaScript has two corresponding methods: File.move or filesystemobject.movefile for moving files; File.Copy or Filesystemobject.copyfile is used to copy files, File.delete or filesystemobject.deletefile to delete files.
The following code demonstrates creating a text file in the root directory of drive C, filling in some content, then moving the file to the \tmp directory, creating a copy of the file under the directory \temp, and finally deleting the files for both directories:
Copy Code code as follows:
Var fso, F1, F2, s;
FSO = new ActiveXObject ("Scripting.FileSystemObject");
F1 = fso. CreateTextFile ("C:\\testfile.txt", true);
Write a line
F1. Write ("This is a test.");
Close File
F1. Close ();
Get the file handle in the C:\ root directory
F2 = fso. GetFile ("C:\\testfile.txt");
Move files to the \tmp directory
F2. Move ("C:\\tmp\\testfile.txt");
Copy files to the \temp directory
F2. Copy ("C:\\temp\\testfile.txt");
Get file Handle
F2 = fso. GetFile ("C:\\tmp\\testfile.txt");
F3 = FSO. GetFile ("C:\\temp\\testfile.txt");
deleting files
F2. Delete ();
F3. Delete ();
Six, the conclusion
With the descriptions and examples of the various objects, properties, and methods of FileSystemObject, I believe you have a clear understanding of how to use the JavaScript language to manipulate drives, files, and folders on a page. However, the above mentioned routines are very simple, to fully and flexibly grasp the JavaScript file operation technology, but also need a lot of practical practice. And it's also a reminder that because of advanced operations involving file reading and writing in a browser, there is an informational prompt before the code runs for the default browser security level, which prompts the visitor to notice in the actual environment.