gpt4 book ai didi

node.js - 如何在现有的 Express 应用程序中使用 Electron

转载 作者:搜寻专家 更新时间:2023-10-31 23:03:02 26 4
gpt4 key购买 nike

我阅读并尝试了类似 https://github.com/frankhale/electron-with-express 上的样本但我仍然不明白如何将 Express 应用程序转换为 Electron

如何将 Electron 与现有的 Express 应用程序一起使用?

以这个 Express 应用为例:

app.js

var express = require("express");
var app = express();

var request = require("request");

app.set("view engine", "ejs");

app.get("/", function(req, res) {
res.render("search");
});

app.get("/results", function(req, res){
var query = req.query.search;
var url = "https://yts.am/api/v2/list_movies.json?sort=seeds&limit=15&query_term='" + query + "'";
request(url, function(error, response, body){
var data = JSON.parse(body);
if(!error && response.statusCode == 200){
//res.send(data["data"]["movies"][0]["title"]);
res.render("results", {data: data});
//["movies"][0]["title"]
}
else
console.log(data);
});
});

app.listen(process.env.PORT, process.env.IP, function(){
console.log("IMDB server has started");
});

search.ejs

Search for a movie

<form action="results" method="GET">
<input type="text" placeholder="search term" name="search">
<input type="submit">
</form>

results.ejs

Results page
<ul>
<% data["data"]["movies"].forEach(function(movie){ %>
<li>
<strong><%= movie["title"]%></strong> - <%= movie["year"]%>
</li>
<% }) %>
</ul>

<a href="/">Search again</a>

最佳答案

在 Electron main.js 文件中,您应该require 您的 app.js 文件来启动 Express 应用程序,然后创建一个新的BrowserWindow 的实例并加载您的 Express 应用程序正在监听的 URL。

请注意,您要么必须在 Electron 中对 IP 和 PORT 进行硬编码,要么从 Express 中导出它们并将它们导入到 Electron main.js 脚本中。

./main.js

const { BrowserWindow, app } = require('electron')
require('./app.js')

let mainWindow = null

function main() {
mainWindow = new BrowserWindow()
mainWindow.loadURL(`http://localhost:3000/`)
mainWindow.on('close', event => {
mainWindow = null
})
}

app.on('ready', main)

./package.json

{
"name": "your-app-name",
"version": "1.0.0",
"description": "A description of your application",
"main": "main.js",
"scripts": {
"start": "electron ."
},
"repository": "https://github.com/link/to/repo",
"keywords": [ "some","keywords" ],
"author": "You",
"license": "Your License",
"dependencies": {
"ejs": "^2.6.1", // required for your specific example where `ejs` package is used
"electron": "^3.0.9",
"express": "^4.16.4"
}
}

然后您需要确保 node_modules 目录与 main.jspackage.json 位于同一目录中。

最后,您可以使用以下方式启动您的 Express/Electron 应用程序:

> npm start

如果您的 Express 应用程序与 Electron 不在同一目录中,则必须相应地为 express 设置 views 目录:

app.js

var path = require('path')
var request = require("request");
var express = require("express");
var app = express();

app.set('views', path.join(__dirname, '/views'));

...

/views 是相对于包含您的 View 的 app.js 的目录。

关于node.js - 如何在现有的 Express 应用程序中使用 Electron,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53346562/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com