如何在纯js(无节点)中编辑文件?
我得到一个带有输入字段的文件,并像这样读取其文本:
var fileReader = new FileReader();
fileReader.readAsText(file);
fileReader.onload = function () {
alert(this.result);
}
所以,非常简单。我尝试在网上查看如何使用 fileWriter 但没有成功。
我只需要编辑该文件中的文本并保存它,该怎么办?
您可以读取文本文件中的数据,在客户端 JavaScript(无 Node)中对其进行修改,然后输出并重新保存。但它确实需要用户交互。
这是我修改的一个 JS 小提琴,它从一些文本中输出文件,尽管它不读取文件。
最初取自这个 Stackoverflow 问题
(function () {
var textFile = null;
function makeTextFile(text) {
var data = new Blob([text], {type: 'text/plain'});
// If we are replacing a previously generated file we need to
// manually revoke the object URL to avoid memory leaks.
if (textFile !== null) {
window.URL.revokeObjectURL(textFile);
}
textFile = window.URL.createObjectURL(data);
return textFile;
}
var create = document.getElementById('create');
var textbox = document.getElementById('textbox');
//create a click event listener
create.addEventListener('click', function () {
var link = document.getElementById('downloadlink');
link.setAttribute('download', 'info.txt');
//make the text file
link.href = makeTextFile(textbox.value);
link.style.display = 'block';
//wait for the link to be rendered and then initiate a click to download the file
window.requestAnimationFrame(function () {
var event = new MouseEvent('click');
link.dispatchEvent(event);
document.body.removeChild(link);
});
}, false);
})();
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)