files/en-us/web/api/filesystemobserver/observe/index.md
{{securecontext_header}}{{APIRef("File System API")}}{{SeeCompatTable}}{{non-standard_header}}
The observe() method of the
{{domxref("FileSystemObserver")}} interface asks the observer to start observing changes to a given file or directory.
observe(handle)
observe(handle, options)
handle
options {{optional_inline}}
observe() call. This can contain the following properties:
recursive
: A boolean specifying whether you want to observe changes to a directory recursively. If set to true, changes are observed in the directory itself and all contained subdirectories and files. If set to false, changes are only observed in the directory itself and directly contained files (that is, files in subdirectories are excluded). Defaults to false.
This property has no effect if handle represents a file.
A {{jsxref("Promise")}} that resolves to {{jsxref('undefined')}}.
NotFoundError {{domxref("DOMException")}}
handle could not be found.Assuming a FileSystemObserver instance is available, you can start observing changes to a file system entry by calling observe().
You can observe a file or directory in the user-observable file system or the Origin Private File System (OPFS) by passing a {{domxref("FileSystemFileHandle")}} or {{domxref("FileSystemDirectoryHandle")}} to observe(). Instances of these objects can be returned, for example, when asking the user to select a file or directory using {{domxref("Window.showSaveFilePicker()")}} or {{domxref("Window.showDirectoryPicker()")}}:
// Observe a file
async function observeFile() {
const fileHandle = await window.showSaveFilePicker();
await observer.observe(fileHandle);
}
// Observe a directory
async function observeDirectory() {
const directoryHandle = await window.showDirectoryPicker();
await observer.observe(directoryHandle);
}
You can also observe changes to the OPFS by passing a {{domxref("FileSystemSyncAccessHandle")}} to observe():
// Observe an OPFS file system entry
async function observeOPFSFile() {
const root = await navigator.storage.getDirectory();
const draftHandle = await root.getFileHandle("draft.txt", { create: true });
const syncHandle = await draftHandle.createSyncAccessHandle();
await observer.observe(syncHandle);
}
To observe a directory recursively, call observe() with the recursive option set to true:
// Observe a directory recursively
async function observeDirectory() {
const directoryHandle = await window.showDirectoryPicker();
await observer.observe(directoryHandle, { recursive: true });
}
Not currently part of a specification. See https://github.com/whatwg/fs/pull/165 for the relevant specification PR.
{{Compat}}