Click here to Skip to main content
Click here to Skip to main content

File Handling at Client Side Using Javascript

By , 28 May 2007
 

Introduction

JavaScript has a very rich ensemble of methods and properties to create, manipulate, and manage drives, files, and folders. You can use JavaScript as you would any other modern programming language. For example, you can use it to open files, write to a file, read from it, etc.

Using the Code

File handling in JavaScript can be done using the FileSystemObject object and its properties and methods. This object is part of Microsoft's Scripting Engine, and thus this is applicable only to Microsoft Windows Operating Systems.

The following piece of code creates a new file at the specified location and write the line "File handling in JavaScript" into it.

var fso = new ActiveXObject("Scripting.FileSystemObject");
// 2=overwrite, true=create if not exist, 0 = ASCII
varFileObject = fso.OpenTextFile("C:\\Sachin.txt", 2, true,0);
varFileObject.write("File handling in Javascript");
varFileObject.close();

The parameters for the function OpenTextFile are as follows:

Parameter 1: PATH - The file gets created at the path specified on the client machine. If only the file name is mentioned here, the file gets saved on the desktop of the client system.

Parameter 2: I/O mode, indicates the mode of file opening. Possible values are:

  • 1: Opens the file for reading.
  • 2: Opens the file for writing.
  • 8: Opens the file for appending.

Parameter 3: CREATE is a boolean value indicating whether to create the file if it does not exist (true) or to issue an error message if the file does not exist (false).

Parameter 4: FORMAT is optional and indicates the file type. If not specified, the default file type is ASCII. The possible values of format are:

  • TristateUseDefault - 2: Opens the file using the system default
  • TristateTrue -1: Opens the file as Unicode
  • TristateFalse 0: Opens the file as ASCII

The following are some of the methods provided by FileSystemObject for file handling:

MoveFile(source, destination)
MoveFolder(source, destination)
CopyFile(source, destination, overwriteFlag) //overwriteFlag= true/false
CopyFolder(source, destination, overwriteFlag) //overwriteFlag= true/false
CreateFolder(folderName)
CreateTextFile(fileName, overwriteFlag)//overwriteFlag= true/false
DeleteFile(fileName, readPermissionFlag)//readPermissionFlag= true/false
DeleteFolder(folderName, readPermissionFlag)//readPermissionFlag= true/false
DriveExists(letterDrive)
FileExists(fileName)
FolderExists(folderName)
GetSpecialFolder(folderCode) /* The given folderCode is either 0 for a 
windows folder, 1 for a system folder, or 2 for a temporary folder. 
A full path is returned. On a typical installation, "c:\windows" 
is returned as the windows folder, "c:\windows\system" is returned 
as the system folder, and "c:\windows\temp" is returned as the temporary folder. */

Points of Interest

There are a few things to note before implementing FileSystemObject. Since it is an ActiveX object, it will not be created if the security level on the client machine is high. So the website has to be added to the trusted site list so that the ActiveX object can be created.

The user must have write access in the path specified while creating a file. In cases where there is uncertainty, it's better to write the file onto the Temporary Folder of the system. The path for the Temp folder can be found using:

GetSpecialFolder(2)

The above topic is applicable only for IE. The below link gives an idea of how to implement file operations in Mozilla. The below code can be used to check the browser type:

if (navigator.userAgent.indexOf("Opera") >= 0)
{
    alert("This example doesn't work in Opera") ; 
    return ;
}
if (navigator.userAgent.indexOf("MSIE") >= 0)
{ 
    alert("This example works in IE") ; 
    return ;
} 
if (navigator.userAgent.indexOf("Mozilla") >= 0)
{
    alert("This example doesn't work in Mozilla") ; 
    alert("Check the following link: <a href="http://www.mozilla.org/js/js-file" + 
          "-object.html" title="http://www.mozilla.org/js/js-file-object" + 
          ".html">http://www.mozilla.org/js/js-file-object.html</a>") ;
    return ;
}

//

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

About the Author

SachinKumarK
Web Developer
India India
Member
No Biography provided

Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
Hint: For improved responsiveness ensure Javascript is enabled and choose 'Normal' from the Layout dropdown and hit 'Update'.
You must Sign In to use this message board.
Search this forum  
    Spacing  Noise  Layout  Per page   
QuestionHow to avoid IE warning messagememberMember 950938412 Oct '12 - 11:18 
Hi Sachin,
 
Great example, but is there any way to avoid this warning message in IE:
 
An ActiveX control on this page might be unsafe to
interact with other parts of the page. Do you want to
allow this interaction?
 
Ted
AnswerRe: How to avoid IE warning messagememberchaitanyasingh19 Feb '13 - 4:14 
Questionto create a image file?memberrarmentadesa5 Oct '12 - 6:42 
Generalcount the no of files in a foldermembervijaylumar1 Apr '10 - 21:16 
GeneralRe: count the no of files in a foldermemberSachinKumarK2 Apr '10 - 7:01 
GeneralError :(memberab_dc11 Aug '08 - 1:24 
GeneralRe: Error :(memberSachinKumarK12 Aug '08 - 4:25 
GeneralRe: Error :(memberab_dc13 Aug '08 - 1:44 
GeneralRe: Error :(memberSachinKumarK13 Aug '08 - 23:27 
GeneralRe: Error :(memberSachinKumarK17 Aug '08 - 22:19 
GeneralRe: Error :(membersarathkumarnallathambi6 Mar '13 - 23:20 
GeneralRegarding reading files in folder ""C:\\Documents and Settings\\Administrator\\Local Settings\\Temporary Internet Files" using javascriptmemberMaheshReddy14 Apr '08 - 20:42 
Generalhimemberrajantawate1(http//rtawate-csharp-book.blogspot.co21 May '07 - 6:41 
GeneralRe: himemberSachinKumarK25 May '07 - 3:59 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Permalink | Advertise | Privacy | Mobile
Web04 | 2.6.130516.1 | Last Updated 29 May 2007
Article Copyright 2007 by SachinKumarK
Everything else Copyright © CodeProject, 1999-2013
Terms of Use
Layout: fixed | fluid