[英]generate a js file dynamically using fs node
我正在尝试通过运行节点脚本来生成 a.js 文件。 这是我的代码。
const dynamicCode = [
{
"ClassCode" : "9620",
"Rate" : 0.99,
"IsActive" : "TRUE",
"StartDate" : "2021-10-19T17:00:00.000-07:00",
"EndDate" : "9999-12-30T16:00:00.000-08:00"
},
{
"ClassCode" : "0038",
"Rate" : 12.19,
"IsActive" : true,
"StartDate" : "2021-05-31T17:00:00.000-07:00",
"EndDate" : "9999-12-30T16:00:00.000-08:00"
}
]
const bdCode = module.exports = {
async up(db, client) {
await db.collection('Configuration_Lookup').deleteMany();
await db.collection('Configuration_Lookup').insertMany(dynamicCode)
},
async down(db, client) {
// TODO write the statements to rollback your migration (if possible)
// Example:
// await db.collection('albums').updateOne({artist: 'The Beatles'}, {$set: {blacklisted: false}});
}
};
fs.writeFileSync("bds.js", JSON.stringify(bdCode, null, 2), 'utf-8');
虽然这适用于包含简单文本的 .txt 文件,或者像 json 对象这样的不可执行代码。 它在运行 writeFileSync function 之前执行。 所以插入js文件的数据是
{}
我们如何生成一个包含工作代码的 js 文件
您可以通过使用 Function 构造函数从中创建 function 来将代码作为字符串运行。
const code = "let x = 100; console.log(x + 1)"; const run = new Function(code); run();
将此字符串写入 JS 文件并使用子进程运行 js 文件。
我通过以下代码解决了这个问题。
const dynamicCode = [
{
"ClassCode" : "9620",
"Rate" : 0.99,
"IsActive" : "TRUE",
"StartDate" : {"$date": "2021-10-19T00:00:00Z"},
"EndDate" : {"$date": "9999-12-30T23:59:59Z"}
},
{
"ClassCode" : "0038",
"Rate" : 12.19,
"IsActive" : true,
"StartDate" : {"$date": "2021-10-19T00:00:00Z"},
"EndDate" : {"$date": "9999-12-30T23:59:59Z"}
}
]
const bdCode = `module.exports = {
async up(db, client) {
await db.collection('Configuration_Lookup').deleteMany();
await db.collection('Configuration_Lookup').insertMany(${JSON.stringify(dynamicCode, null, 2)})
},
async down(db, client) {
// TODO write the statements to rollback your migration (if possible)
// Example:
// await db.collection('albums').updateOne({artist: 'The Beatles'}, {$set: {blacklisted: false}});
}
};`
fs.writeFileSync("bds.js", bdCode);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.