-
Notifications
You must be signed in to change notification settings - Fork 0
PhoneGap Cordova File System FAQ
- When does it make sense to use the file system (versus LocalStorage or WebSQL)?
- How do I download an asset to my application?
- How do I use a file stored in the file system (both binary and text-based files)?
- How do I check to see if a file exists in a directory?
- Are there external tools that can check a device's file system?
- How do I check to see if a directory exists?
- How do I make a subdirectory where the parent directory may not exist?
- Are there any app store restrictions/guidelines for using the file system?
- For iOS, where can I store files so that they will be backed up to iCloud?
- How can I get metadata (size, updated) about a file?
First - remember that storing data locally is something you should consider when building any application. Data can be slow to transfer to the end user. The end user may be offline. Data may be static and not change often. There's a variety of reasons why you should consider ensuring you only download data once, or only once in a while at minimum.
A Cordova application can store data locally in a variety of ways: Local Storage, Web SQL, IndexedDB (only in very recent browsers though), and the File System. So when would the file system make sense?
While there aren't strict rules on when you would use one over the other, in general, the guidelines I follow for storage are as follows:d
Local Storage is useful for simple key/value type storage. For example, storing the user's username, their favorite color. You can store a lot of data in Local Storage, but in general I tend to use it mainly for preferences.
WebSQL (and IndexedDB) are better for ad hoc, user-created style content. So for example, if the application lets the user take notes, then WebSQL would be more preferable. It is easier to search and aggregate large sets of data with WebSQL versus Local Storage.
But where both Local Storage and Web SQL are good at storing data, binary data and files make more sense on the file system. You can encode binary data in Base64, but that can be an expensive process. Since you do have a file system available to you, it makes sense to make use of it for file based data.
You can download assets to your application two ways. The first way is via the typical AJAX request. Any AJAX request that returns data can be used to fetch data that can then be written to the file system using the File System API. Modern browsers can handle binary data, but this technique is typically used for text files.
The preferred way to download an asset would be to make use of the File Transfer API. The download method of the File Transfer API will let you easily grab a file of any form and save it to the local file system. It has callbacks for successful and errored results as well as an onprogress event that can be used to monitor how much data has been sent. You can also abort an existing transfer.
Reference: https://github.com/apache/cordova-plugin-file-transfer/blob/master/doc/index.md How do I use a file stored in the file system (both binary and text-based files)? It depends on what you mean by "use" of course. Let's look at a few simple examples.