перезаписать файл с помощью HTML5 FileWriter
Я использую HTML5 FileWriter API чтобы сохранить состояние моего webapp. У меня есть бит JS, который периодически вызывает FileWriter.write
чтобы сделать это (так, со временем,write
метод вызывается несколько раз). По умолчанию FileWriter API использует "добавочный" подход к написанию файлов, который не соответствует моим потребностям, так как я не хочу перезаписывать содержимое файла.
Я впервые попробовал этот:
this._writer.seek(0);
this._writer.write(content);
это не работает, когда вы пишете текст короче, чем файл содержание. Затем я попробовал это:
this._writer.truncate(0);
this._writer.write(content);
этот код должен очистить файл и затем записать мой новый контент, но я получаю следующую ошибку, когда write
метод называется:
Uncaught InvalidStateError: An operation that depends on state cached in an interface object was made but the state had changed since it was read from disk.
странная вещь: когда я отлаживаю код (с точкой останова), ошибка не возникает, как будто FileWriter.truncate
был асинхронным методом...
Я застрял здесь, есть идеи?
Я использую Chrome 30.0.1599.69
5 ответов
вот правильный код, который не будет тратить 500 мс на ожидание
fileWriter.onwriteend = function() {
if (fileWriter.length === 0) {
//fileWriter has been reset, write file
fileWriter.write(blob);
} else {
//file has been overwritten with blob
//use callback or resolve promise
}
};
fileWriter.truncate(0);
вы можете усечь, а затем написать с двумя разными FileWriter
объекты.
fileEntry.createWriter(function (fileWriter) {
fileWriter.truncate(0);
}, errorHandler);
fileEntry.createWriter(function (fileWriter) {
var blob = new Blob(["New text"], { type: 'text/plain' });
fileWriter.write(blob);
}, errorHandler);
Если вы хотите всегда переопределять его, вы можете использовать этот метод
function save(path,data){
window.resolveLocalFileSystemURL(dataDirectory, function(dir){
dir.getFile(path, {create:true}, function(file){
file.createWriter(function(fileWriter){
fileWriter.seek(0);
fileWriter.truncate(0);
var blob = new Blob([data], {type:'text/plain'});
fileWriter.write(blob);
}, function(e){
console.log(e);
});
});
});
};
обходным путем является следующий код:
this._writer.truncate(0);
window.setTimeout(function(){
this._writer.write(content);
}.bind(this),500)
это просто подождите 500 миллисекунд перед записью. Не очень, но работает...
Это самый простой способ, как я использую для удаления содержимого файла с syncFileSystem в моем приложении Chrome.
два createWriter, первый усекает, а второй ничего не перезаписывает (вы можете изменить свое новое значение):
file.createWriter((fileWriter)=>fileWriter.truncate(0));
file.createWriter((fileWriter)=> {
fileWriter.onwriteend = function() {
console.log('New Actions!');
};
var blob = new Blob([''], {type: 'text/plain'});
fileWriter.write(blob);
});