如何将node js前端代码与后端代码分开?
Posted
技术标签:
【中文标题】如何将node js前端代码与后端代码分开?【英文标题】:How to separate node js frontend code from backend code? 【发布时间】:2020-11-04 12:42:55 【问题描述】:问题:
我对 node js 还很陌生,发现将前端与后端分开非常困难。 (我不完全理解这些概念)。
为什么?
我需要使用 Apache Cordova 将我的网络应用程序转换为混合应用程序。
具体案例代码:
index.html:
<!doctype html>
<html>
<head>
<title>Socket.IO chat</title>
<style>
* margin: 0; padding: 0; box-sizing: border-box;
body font: 13px Helvetica, Arial;
form background: #000; padding: 3px; position: fixed; bottom: 0; width: 100%;
form input border: 0; padding: 10px; width: 90%; margin-right: 0.5%;
form button width: 9%; background: rgb(130, 224, 255); border: none; padding: 10px;
#messages list-style-type: none; margin: 0; padding: 0;
#messages li padding: 5px 10px;
#messages li:nth-child(odd) background: #eee;
</style>
</head>
<body>
<ul id="messages"></ul>
<form action="">
<input id="m" autocomplete="off" /><button>Send</button>
</form>
<script src="/socket.io/socket.io.js"></script>
<script src="https://code.jquery.com/jquery-3.4.1.min.js"></script>
<script>
window.prompt('Name ?');
$('#messages').append($('<li>').text('You joined !'));
$(function ()
var socket = io();
$('form').submit(function(e)
e.preventDefault(); // prevents page reloading
socket.emit('chat message', $('#m').val());
$('#m').val('');
return false;
);
socket.on('chat message', function(msg)
$('#messages').append($('<li>').text(msg));
);
);
</script>
</body>
</html>
index.js:
var app = require('express')();
var http = require('http').createServer(app);
var io = require('socket.io')(http);
app.get('/', (req, res) =>
res.sendFile(__dirname + '/index.html');
);
io.on('connection', (socket) =>
console.log('a user connected');
socket.on('chat message', (msg) =>
io.emit('chat message', msg);
);
socket.on('disconnect', () =>
console.log('user disconnected');
);
socket.on('chat message', (msg) =>
console.log('message: ' + msg);
);
);
http.listen(3000, () =>
console.log('listening on *:3000');
);
我包含 package.json 依赖项,以便您也可以尝试修复它:
"dependencies":
"express": "^4.17.1",
"socket.io": "^2.3.0"
,
我尝试了什么:
• 搜索了所有 GitHub 和 *** 论坛。 • 尝试自己分离代码。 • 就是这样。
【问题讨论】:
您要准确分离哪些部分?在该特定代码示例中,html 是 Cordova 的前端。 index.js 和 deps 是后端节点服务。 是的,但是当我将 index.html 转换为 android 应用程序并且它没有 index.js(backend) 可以侦听或服务的开放端口时,如何为它提供服务? 您的应用需要 Socket.IO 服务器。您到底希望在这里发生什么? @AnmolVashisht index.html 内容通常打包在应用程序本身内部。后端服务仍然在节点中运行,在某处的服务器上,而不是在科尔多瓦应用程序中。该服务通常托管在所有运行 android 应用程序的人都可以访问它的地方(如 aws) @AnmolVashisht Node.js 代码 (index.js) 无法在 Android 上运行。 【参考方案1】:前端基本上是将发送给用户的 html 文件。它包含所有视觉效果,基本上是与您的后端对话的门户。在您的情况下,它是 index.html
后端处理用户所有传入的http请求。在您的情况下,它处理客户端发送的 socketio 请求。它是执行业务逻辑和与数据库交互的地方。
它们可以被视为不同的项目,因为它们在不同的层上运行。表示层和业务逻辑/应用层。但在最终产品中它们是相关的,因为服务器需要将 html 文件发送到客户端,并且 http-requests 必须在服务器端和客户端匹配。
Nodejs 和 express 是构建 RESTful Web 服务的好方法,这只是一种检索原始数据的方法,其中没有任何表示逻辑。前端负责相应地显示数据。
【讨论】:
我明白这一点并感谢您的时间,但我对后端 js 文件 (index.js) 正在为 index.html 提供服务并在 localhost 的 3000 端口上监听它这一事实感到困惑,但是我应该如何将前端和后端完全分开,即使它们可以托管在完全不同的平台上? 我想我现在明白你的问题了。您需要构建一个 cordova 应用程序,但您目前正在通过服务器提供 html 文件,您现在的问题是将提供的 html 文件外包给一个 cordova 应用程序。 当我将 index.html 转换为 android 应用程序并且它没有 index.js(backend) 可以监听或服务的开放端口时,如何为它提供服务?跨度> 没有提供 index.html。代码基本上会与服务器建立套接字连接。因此,客户端将向服务器发送一个 http 请求,它会保持连接处于活动状态以来回传输数据。服务器不需要知道客户端的任何端口。 index.js 不需要任何更改(除了可能发送 html 文件)。 Cordova 应用程序是客户端,需要一个处理消息的服务器 (index.js)。 Cordova 应用程序需要发送一个 http 请求,让服务器知道他是应用程序的客户端,并且客户端想要接收新消息。服务器将处理所有传入的请求并将它们注册为新消息的订阅者。唯一会改变的是发送到服务器的请求不是像chrome这样的浏览器,而是cordova应用程序框架。以上是关于如何将node js前端代码与后端代码分开?的主要内容,如果未能解决你的问题,请参考以下文章