Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten.Erfahre mehr über dieses Experiment.
FileSystemWritableFileStream: write()-Methode
Baseline 2025Newly available
Since September 2025, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.
Sicherer Kontext: Diese Funktion ist nur insicheren Kontexten (HTTPS) in einigen oder allenunterstützenden Browsern verfügbar.
Hinweis: Diese Funktion ist inWeb Workers verfügbar.
Diewrite()-Methode desFileSystemWritableFileStream-Interfaces schreibt Inhalte in die Datei, auf die die Methode aufgerufen wird, an der aktuellen Dateicursor-Position.
Keine Änderungen werden auf die tatsächliche Datei auf der Festplatte geschrieben, bis der Stream geschlossen wurde. Änderungen werden typischerweise stattdessen in eine temporäre Datei geschrieben. Diese Methode kann auch verwendet werden, um zu einem Byte-Punkt innerhalb des Streams zu suchen und ihn zu kürzen, um die Gesamtanzahl der Bytes, die die Datei enthält, zu ändern.
In diesem Artikel
Syntax
write(data)Parameter
dataKann eines der folgenden sein:
- Die Dateidaten, die in Form eines
ArrayBuffer,TypedArray,DataView,Bloboder Strings geschrieben werden sollen. - Ein Objekt, das die folgenden Eigenschaften enthält:
typeEin String, der entweder
"write","seek"oder"truncate"ist.dataDie Dateidaten, die geschrieben werden sollen. Kann ein
ArrayBuffer,TypedArray,DataView,Bloboder String sein. Diese Eigenschaft ist erforderlich, wenntypeauf"write"gesetzt ist.positionDie Byte-Position, zu der der aktuelle Dateicursor bewegt werden soll, wenn
typeauf"seek"gesetzt ist. Kann auch gesetzt werden, wenntypeauf"write"ist, wobei das Schreiben an der angegebenen Position beginnt.sizeEine Zahl, die die Anzahl der Bytes repräsentiert, die der Stream enthalten soll. Diese Eigenschaft ist erforderlich, wenn
typeauf"truncate"gesetzt ist.
- Die Dateidaten, die in Form eines
Rückgabewert
EinPromise dasundefined zurückgibt.
Ausnahmen
NotAllowedErrorDOMExceptionAusgelöst, wenn
PermissionStatus.statenichtgrantedist.QuotaExceededErrorAusgelöst, wenn die neue Größe der Datei größer ist als die ursprüngliche Größe der Datei und dasSpeicherlimit des Browsers überschreitet.
TypeErrorAusgelöst, wenn
dataundefiniert ist oder wennpositionodersizeungültig sind.
Beispiele
Die folgende asynchrone Funktion öffnet den 'Datei speichern'-Picker, der einenFileSystemFileHandle zurückgibt, sobald eine Datei ausgewählt ist. Daraus wird ein schreibbarer Stream erstellt, indem die MethodeFileSystemFileHandle.createWritable() verwendet wird.
Ein Textstring wird dann in den Stream geschrieben, welcher anschließend geschlossen wird.
async function saveFile() { try { // create a new handle const newHandle = await window.showSaveFilePicker(); // create a FileSystemWritableFileStream to write to const writableStream = await newHandle.createWritable(); // write our file await writableStream.write("This is my file content"); // close the file and write the contents to disk. await writableStream.close(); } catch (err) { console.error(err.name, err.message); }}Die folgenden Beispiele zeigen verschiedene Optionen, die an diewrite()-Methode übergeben werden können.
// just pass in the data (no options)writableStream.write(data);// writes the data to the stream from the determined positionwritableStream.write({ type: "write", position, data });// updates the current file cursor offset to the position specifiedwritableStream.write({ type: "seek", position });// resizes the file to be size bytes longwritableStream.write({ type: "truncate", size });Spezifikationen
| Specification |
|---|
| File System> # api-filesystemwritablefilestream-write> |