FileSystemDirectoryEntry: getFile() method
  The FileSystemDirectoryEntry interface's method
  getFile() returns a
  FileSystemFileEntry object corresponding to a file contained somewhere
  within the directory subtree rooted at the directory on which it's called.
Syntax
getFile()
getFile(path)
getFile(path, options)
getFile(path, options, successCallback)
getFile(path, options, successCallback, errorCallback)
Parameters
- pathOptional
- 
    A string specifying the path, relative to the directory on which the method is called, describing which file's entry to return. 
- optionsOptional
- 
    An object which allows you to specify whether or not to create the entry if it's missing and if it's an error if the file already exists. These options are currently not useful in Web contexts. See the options parameter section for more details. 
- successCallbackOptional
- 
    A method to be called once the FileSystemFileEntryhas been created. The method receives a single parameter: theFileSystemFileEntryobject representing the file in question.
- errorCallbackOptional
- 
    A method to be called if an error occurs. Receives as its sole input parameter a DOMExceptionobject describing the error which occurred.
options parameter
The options parameter object accepts the following parameters:
- createOptional
- 
    If this property is true, and the requested file doesn't exist, the user agent should create it. The default isfalse. The parent directory must already exist.
- exclusiveOptional
- 
    If true, and thecreateoption is alsotrue, the file must not exist prior to issuing the call. Instead, it must be possible for it to be created newly at call time. The default isfalse. This parameter is ignored ifcreateisfalse.
The table below describes the result of each possible combination of these flags depending on whether or not the target file path already exists.
| createoption | exclusiveoption | Path condition | Result | 
|---|---|---|---|
| false | Ignored | Path exists and is a file | The successCallbackis called with aFileSystemFileEntry. | 
| false | Ignored | Path exists but is a directory | The errorCallbackis called with an appropriate error code (if the callback was provided). | 
| true | false | Path exists | The existing file is removed and replaced with a new one, then the successCallbackis called with aFileSystemFileEntry. | 
| true | false | Path doesn't exist | The file is created, then a FileSystemFileEntryis passed to thesuccessCallback. | 
| true | true | Path exists | The errorCallbackis called with an appropriate error, such asFileError.PATH_EXISTS_ERR. | 
| true | true | Path doesn't exist | The file is created, then a FileSystemFileEntryis passed to thesuccessCallback. | 
Return value
None (undefined).
Exceptions
- NotFoundError- DOMException
- 
    Thrown if the createoption was not specified (or was specified asfalse), and the file doesn't exist.
- SecurityError- DOMException
- 
    Thrown if the request to access the file was denied for security reasons. 
- TypeMismatchError- DOMException
- 
    Thrown if the path specified is not a file; it's probably a directory, but might be an unsupported file descriptor such as a pipe; this depends on the user agent to some extent. 
Examples
In this example, a function is presented whose job it is to locate within a user's app data directory a JSON file containing a user dictionary for a specified language, then load that dictionary.
let dictionary = null;
function loadDictionaryForLanguage(appDataDirEntry, lang) {
  dictionary = null;
  appDataDirEntry.getDirectory("Dictionaries", {}, (dirEntry) => {
    dirEntry.getFile(`${lang}-dict.json`, {}, (fileEntry) => {
      fileEntry.file((dictFile) => {
        let reader = new FileReader();
        reader.addEventListener("loadend", () => {
          dictionary = JSON.parse(reader.result);
        });
        reader.readAsText(dictFile);
      });
    });
  });
}
  The loadDictionaryForLanguage() function starts by using
  getDirectory() to obtain the FileSystemDirectoryEntry object
  representing a subfolder named "Dictionaries" located inside the specified app data
  directory. The success callback for this takes the resulting directory entry object and
  calls getFile() to get a
  FileSystemFileEntry object representing the dictionary file; the success
  callback for this, in turn, creates a new FileReader and uses it to load
  the contents of the file. When that is loaded successfully (as indicated by the
  loadend event being fired), the loaded text is passed into
  JSON.parse() to be reconstituted into a JavaScript object.
Specifications
| Specification | 
|---|
| File and Directory Entries API # dom-filesystemdirectoryentry-getfile | 
Browser compatibility
BCD tables only load in the browser