如何将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前端代码与后端代码分开?的主要内容,如果未能解决你的问题,请参考以下文章

前端与后端解耦,使用啥 JS 框架/库?

前端(React)如何与后端(Express)交互?

将前端 Angular 5 和后端 Web API 代码分开的简单方法?

使用 mock.js 让前端开发与后端独立

前端开发与后端开发的区别是什么?

怎么看前端有没有展示后端的数据