Electron App节点集成:如何在POST后访问require()

时间:2015-05-29 22:53:08

标签: javascript node.js electron

我正在构建一个电子应用程序并遇到一个问题,当页面POST到自身时需要未定义。我的目标是使用电子作为现有网站的包装,不幸的是这个网站有这种帖子。在使用preload和executeJavascript进行大量试验和错误后,我发现使用require()和节点集成工作。这是除非请求是POST。我对Electron和节点都很陌生,所以也许我只是错过了一些简单的东西!

我在Electron 0.26.0和0.27.1中得到了这种行为。

这是重新创建问题的最简单方法。

的package.json

{
"name": "PostExample",
"version": "0.1.0",
"main": "main.js",
"description": "Post Loses Global"
}

main.js

var app = require('app')
var BrowserWindow = require('browser-window')

var mainWindow = null;

app.on('window-all-closed', function() {
    app.quit()
});

app.on('ready', function() {

    mainWindow = new BrowserWindow({ 
        "node-integration": true,
    });

    mainWindow.loadUrl('file://' + __dirname + '/index.html')

    mainWindow.openDevTools()

});

的index.html

<html>
 <script type="text/javascript">
    console.log(typeof global)
    try{
        var fs = require("fs");
    } catch(e){
        console.warn("ERROR", e)
    }
 </script>
<body>
 <h1>Posts to self</h1>
 <form action="" method="post">
    <input type="text" name="somevar" value="val" />
    <button type="submit">Go</button>
 </form>
</body>
</html>

0 个答案:

没有答案