我的Electron项目工作目录中名为 data 的目录中有一些JSON文件。我使用electron-build
使用以下配置(package.json)成功构建了应用程序。
{
"name": "My App",
"version": "0.0.9",
"description": "TEST DESC",
"main": "main.js",
"scripts": {
"start": "electron .",
"pack": "build --dir",
"dist": "build"
}
"author": "Test",
"license": "CC0-1.0",
"build": {
"appId": "test.tester.test",
"directories": {
"app": ""
},
"extraFiles": [
"data"
],
"dmg": {
"contents": [
{
"x": 110,
"y": 150
},
{
"x": 240,
"y": 150,
"type": "link",
"path": "/Applications"
}
]
},
"win": {
"target": "squirrel",
"icon": "build/icon.ico"
}
},
"devDependencies": {
"electron": "~1.7.8",
"electron-builder": "^20.11.1"
},
"dependencies": {
"electron-settings": "^3.1.4",
"jquery": "^3.3.1",
"leveldown": "^3.0.0",
"mkdirp": "^0.5.1",
"shelljs": "^0.8.1"
}
}
我认为数据目录没有添加到构建文件中。因为我使用数据目录中的文件来渲染应用程序中的视图,这在构建的应用程序中不起作用。请提出解决方案。
我在应用程序中使用这些JSON文件,如下所示:
fs.readFile('./data/userdata.json', 'utf8', function readFileCallback(err, data) {
if(data == '') { data = '[]'; }
var users = JSON.parse(data);
//Render Code
});
答案 0 :(得分:3)
"build": {
"extraResources": [
{
"from": "data",
"to": "data"
}
]
}
这样添加后,然后Electron-builder在打包应用程序后将数据文件夹复制到应用程序的资源/数据。这样您就可以使用 这个。
const dataPath =
process.env.NODE_ENV === 'development'
? path.join(__dirname, '../../data')
: path.join(process.resourcesPath, 'data');
fs.readFile(path.join(dataPath,'userdata.json', 'utf8', function readFileCallback(err, data) {
if(data == '') { data = '[]'; }
var users = JSON.parse(data);
//Render Code
});