假设我有一个如下所示的javascript对象:
var data = {
name: "cliff",
age: "34",
name: "ted",
age: "42",
name: "bob",
age: "12"
}
var jsonData = JSON.stringify(data);
我将其字符串化以转换为JSON。如何将此JSON保存到本地文本文件,以便我可以在记事本等中打开它。
答案 0 :(得分:100)
Node.js:
var fs = require('fs');
fs.writeFile("test.txt", jsonData, function(err) {
if (err) {
console.log(err);
}
});
浏览器(webapi):
function download(content, fileName, contentType) {
var a = document.createElement("a");
var file = new Blob([content], {type: contentType});
a.href = URL.createObjectURL(file);
a.download = fileName;
a.click();
}
download(jsonData, 'json.txt', 'text/plain');
答案 1 :(得分:5)
这是纯js的解决方案。你可以用html5 saveAs来做。例如,这个lib可能会有所帮助:https://github.com/eligrey/FileSaver.js
看看演示:http://eligrey.com/demos/FileSaver.js/
附:没有关于json save的信息,但您可以将文件类型更改为"application/json"
并格式化为.json
答案 2 :(得分:5)
这是将本地数据保存到txt文件的解决方案。
function export2txt() {
const originalData = {
members: [{
name: "cliff",
age: "34"
},
{
name: "ted",
age: "42"
},
{
name: "bob",
age: "12"
}
]
};
const a = document.createElement("a");
a.href = URL.createObjectURL(new Blob([JSON.stringify(originalData, null, 2)], {
type: "text/plain"
}));
a.setAttribute("download", "data.txt");
document.body.appendChild(a);
a.click();
document.body.removeChild(a);
}
<button onclick="export2txt()">Export data to local txt file</button>
答案 3 :(得分:0)
采用了dabeng解决方案,我已经将其转录为类方法。
class JavascriptDataDownloader {
constructor(data={}) {
this.data = data;
}
download (type_of = "text/plain", filename= "data.txt") {
let body = document.body;
const a = document.createElement("a");
a.href = URL.createObjectURL(new Blob([JSON.stringify(this.data, null, 2)], {
type: type_of
}));
a.setAttribute("download", filename);
body.appendChild(a);
a.click();
body.removeChild(a);
}
}
new JavascriptDataDownloader({"greetings": "Hello World"}).download();