我正在尝试使用preload script来解决电子4.2.3中的CORS header issue。但是,我无法运行预加载脚本。一个最小的复制情况:
package.json
{
"name": "your-app",
"version": "0.1.0",
"main": "main.js",
"dependencies": {
"electron": "^4.2.3"
}
}
main.js
const { app, BrowserWindow } = require('electron')
app.on('ready', function() {
const win = new BrowserWindow({
webPreferences: {
preload: `file://${__dirname}/preload.js`,
}
})
win.webContents.openDevTools()
win.loadFile('index.html')
})
preload.js
window.preloadWasRun = 'preload was run'
index.html
<body>
<script>
document.write(window.preloadWasRun || 'preload was not run')
</script>
</body>
无论我为webSecurity
,nodeIntegration
和contextIsolation
使用什么设置,似乎我的preload
脚本都被忽略了。即使我在脚本中出现语法错误,也不会在任何地方显示任何错误。
答案 0 :(得分:2)
原来,它必须是绝对路径名,而不是绝对URL。这些都不起作用:
preload: `file://${__dirname}/preload.js`,
preload: './preload.js',
preload: 'preload.js',
但这可以像宣传的那样工作:
preload: `${__dirname}/preload.js`,
由于它似乎是文件系统路径而不是URL,所以明智的是使用path.join
来解决具有奇怪路径分隔符的平台:
preload: path.join(__dirname, 'preload.js'),