我一直在学习如何使用MEAN堆栈来构建网络应用程序,到目前为止,它已经非常有趣。我没有使用yeoman生成器或npm应用程序为我生成代码,而是从头开始构建我的整个应用程序。通过这种方式,我知道每个部分如何连接以及我的应用程序发生了什么。当我查看开发人员控制台并看到
时,我才开始连接应用程序的前端和后端GET http://blog.dev/bower_components/angular/angular.js
不仅有角度,还有我拥有的所有其他资源(Modernizr,angular-routes,mootools,restangular等等)。当你使用yeoman角度生成器时,你应该运行grunt serve
命令来启动角度侧。因为我从头开始构建应用程序,并且我使用npm作为构建工具,所以我不知道如何构建前端服务器。所以,我只是使用一个指向我的index.html的简单nginx虚拟主机。这是配置:
server {
listen 80;
server_name blog.dev;
root /home/michael/Workspace/blog/app;
index index.html index.htm;
location / {
try_files $uri $uri/ =404;
}
}
我不确定其他变量可能会对这种情况产生什么影响,所以如果我错过了什么,请告诉我,我很乐意为您提供所需的信息!
答案 0 :(得分:5)
如果你正在使用平均堆栈,你应该能够托管后端并直接用节点服务于前端。
我不确定你的项目结构,但这是我现在正在研究的结构。
/bin --contains a file called www.js (used to launch app)
/data
/models
/node_modules
/public -- contains my angular implementation
/routes -- contains express routes
/temp
/upload
/views
app.js -- main configuration for express
api.js -- my apis
package.json
在/bin/www.js文件中,您有代码来启动节点服务器。
var app = require('../app');
app.set('port', process.env.PORT || 3000);
var server = app.listen(app.get('port'), function() {
debug('Express server listening on port ' + server.address().port);
});
您还需要设置快递和路线,以便先查看路线 在routes目录中,我有一个名为index.js
的文件在这个文件中,我定义了一条通向我的angular index.html页面的路线。
var express = require('express');
var router = express.Router();
/* GET home page. */
router.get('/', function(req, res) {
res.redirect('/pages/index.html');
});
module.exports = router;
当然,你需要设置快递。
process.env.TMPDIR = 'tmp'; // to avoid the EXDEV rename error, see http://stackoverflow.com/q/21071303/76173
var express = require('express');
var path = require('path');
var favicon = require('static-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var multer = require('multer');
var flow = require('./flow-node.js')('tmp');
var multipart = require('connect-multiparty');
var multipartMiddleware = multipart();
var uuid = require('uuid');
var mongoose = require('mongoose');
var session = require('express-session');
var routes = require('./routes/index');
var app = express();
app.use(favicon());
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
app.use(cookieParser());
app.use(session({genid: function(req) { return uuid.v4()}, secret: 'XXXXXXXXXXX',
saveUninitialized: true,
resave: true}));
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', routes);
app.use('/users', users);
module.exports = app;
现在假设你在某个地方的'public'目录中有你的Angular文件和javascript,你应该能够使用以下命令启动Node。
node bin/www
您的浏览器指向http://localhost:3000并开始营业。
希望这有助于学习。