“不是found"在浏览器中的明文,当试图渲染模板与swig对koajs

"not found" plaintext in browser, when trying to render template with swig on koajs

本文关键字:koajs swig quot found 不是 明文 浏览器      更新时间:2023-09-26

我正在使用node.js和swig模板引擎上的koajs来学习和编写web服务。目前,浏览器只加载"未找到"字样。在我试图将程序拆分为多个文件之前,代码工作了。在那之后,我试着让它工作,甚至把所有的东西都放在一个文件里,但没有成功。

在'./templates/base.html'的html文件确实存在。为了澄清,当我运行"node -harmony index.js"时,没有错误,我确实得到了"监听端口3000"的输出。但是当我尝试在浏览器中加载页面时,我得到纯文本"未找到"。

这是我的文件:

index.js:

var routes = require('./routes');
var server = require('./server');

routes.baseroute
server.init(3000);

server.js:

var serve = require('koa-static');
var koa = require('koa');
var app = koa();

var init = function(port){
  app.use(serve('./public'));
  app.listen(port);
  console.log(''n   ---> listening on port '+port);
};
exports.init = init;

routes.js:

var koa = require('koa');
var route = require('koa-route');
var views = require('./views');
var app = koa();

var baseroute = app.use(route.get('/', views.baseview));
exports.baseroute = baseroute;

views.js:

var swig = require('swig');
var data = require('./data');

var baseview = function*(){
  var tpl = swig.compileFile('./templates/base.html');
  this.body = tpl(data.basedata);
};
exports.baseview = baseview;

data.js:

var basedata = {user: 'testuser123'};
exports.basedata = basedata;

所以真正发生的是,当您将它们拆分到它们自己的文件中时,您在它们自己的文件中创建了一个单独的koa实例。看到:-
var app = koa();
server.jsroutes.js中,koa认为它们是独立的应用程序。在koa中可以有多个应用程序,但你必须挂载它们,以便它们有任何形式的链接。首先,找到要进行链接的主文件。我猜这是server.js,并从他们的文件(route.js)中暴露其他app。现在,当你连接它们的时候,只要使用mount('/', require('./routes'));koa就可以将它们连接成一个单元。总之:-

//routes.js
var koa = require('koa');
...
...
var app = koa();
app.use(route.get('/', views.baseview));
module.exports = app;
//server.js
var app = require('koa');
var mount = require('koa-mount');
var routes = require('./routes');
...
...
var init = function(port){
  app.use(serve('./public'));
  app.use(mount('/route', routes));
  app.listen(port);
  console.log(''n   ---> listening on port '+port);
};   
exports.init = init;