我正在尝试HTML5文件API,我需要使用一个我不太了解的方法(因为它几乎没有记录在任何地方)。
我在谈论FileWriter truncate()方法,我知道它做了我需要做的事情。基本上,不是将文本附加到某些文件数据或使用seek()来覆盖某个部分,我想用其他东西覆盖所有数据(例如从“somedata”覆盖到“”)。
以下是HTML5Rocks的FileWriter设置片段,其中添加了truncate()。
function onInitFs(fs) {
fs.root.getFile('log.txt', {create: false}, function(fileEntry) {
// Create a FileWriter object for our FileEntry (log.txt).
fileEntry.createWriter(function(fileWriter) {
fileWriter.seek(fileWriter.length); // Start write position at EOF.
fileWriter.truncate(1);
// Create a new Blob and write it to log.txt.
var bb = new BlobBuilder(); // Note: window.WebKitBlobBuilder in Chrome 12.
bb.append('Hello World');
fileWriter.write(bb.getBlob('text/plain'));
}, errorHandler);
}, errorHandler);
}
window.requestFileSystem(window.PERSISTENT, 1024*1024, onInitFs, errorHandler);
当调用writer.truncate()时,调用writer.write()会引发File Exception错误。我相信这是因为readyState设置为WRITING。不幸的是,我不知道如何解决这个问题。
我已经尝试了查看HTML5Rocks section,但它没有告诉我有关truncate()方法的任何信息(虽然我知道它存在于Webkit JS控制台告诉我的内容)。 / p>
长话短说,我怎样才能正确使用truncate()方法而不会出错?
答案 0 :(得分:11)
这样的事情可能会更加重要:
truncate 将文件的长度更改为指定的
fileEntry.createWriter(function(fileWriter) {
var truncated = false;
fileWriter.onwriteend = function(e) {
if (!truncated) {
truncated = true;
this.truncate(this.position);
return;
}
console.log('Write completed.');
};
fileWriter.onerror = function(e) {
console.log('Write failed: ' + e.toString());
};
var blob = new Blob(['helo'], {type: 'plain/text'});
fileWriter.write(blob);
}, errorHandler);
答案 1 :(得分:7)
你需要更加不同寻常。 :)
fileEntry.createWriter(function(fileWriter) {
fileWriter.onwriteend = function(trunc) {
fileWriter.onwriteend = null; // Avoid an infinite loop.
// Create a new Blob and write it to log.txt.
var bb = new BlobBuilder(); // Note: window.WebKitBlobBuilder in Chrome 12.
bb.append('Hello World');
fileWriter.write(bb.getBlob('text/plain'));
}
fileWriter.seek(fileWriter.length); // Start write position at EOF.
fileWriter.truncate(1);
}, errorHandler);