2017-06-13 76 views
1

我创建了一个完全在Angular上运行的MEAN栈应用程序。我试图将其托管到Heroku,但Heroku需要Node才能运行该应用程序。因此,当我运行Heroku应用程序时,它将访问该节点端口,并显示在开始时建立的基本索引视图。如何使用Node/Express运行纯粹的前端Angular应用程序?

我知道如何在节点中显示视图,但我不清楚如何在节点端口运行时显示Angular应用程序。

可以指定角度端口作为节点视图渲染的一部分吗?或者也许重定向节点来显示Angular端口呢?

App.js

var express = require('express'); 
var path = require('path'); 
var favicon = require('serve-favicon'); 
var logger = require('morgan'); 
var cookieParser = require('cookie-parser'); 
var bodyParser = require('body-parser'); 
var ejs = require('ejs'); 

var index = require('./routes/index'); 
var users = require('./routes/users'); 

var app = express(); 

// view engine setup 
app.set('views', path.join(__dirname, 'views')); 
app.set('view engine', 'ejs'); 

// uncomment after placing your favicon in /public 
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico'))); 
app.use(logger('dev')); 
app.use(bodyParser.json()); 
app.use(bodyParser.urlencoded({ extended: false })); 
app.use(cookieParser()); 
app.use(express.static(path.join(__dirname, 'public'))); 

app.use('/', index); 
app.use('/users', users); 

// catch 404 and forward to error handler 
app.use(function(req, res, next) { 
    var err = new Error('Not Found'); 
    err.status = 404; 
    next(err); 
}); 

// error handler 
app.use(function(err, req, res, next) { 
    // set locals, only providing error in development 
    res.locals.message = err.message; 
    res.locals.error = req.app.get('env') === 'development' ? err : {}; 

    // render the error page 
    res.status(err.status || 500); 
    res.render('error'); 
}); 

module.exports = app; 

Index.js路线

var express = require('express'); 
var router = express.Router(); 

/* GET home page. */ 
router.get('/', function(req, res, next) { 
    res.render('index', { title: 'Express' }); 
}); 

module.exports = router; 

斌/ WWW

#!/usr/bin/env node 

/** 
* Module dependencies. 
*/ 

var app = require('../app'); 
var debug = require('debug')('aether-news:server'); 
var http = require('http'); 

/** 
* Get port from environment and store in Express. 
*/ 

var port = normalizePort(process.env.PORT || '3000'); 


app.set('port', port); 

/** 
* Create HTTP server. 
*/ 

var server = http.createServer(app); 

/** 
* Listen on provided port, on all network interfaces. 
*/ 

server.listen(port); 
server.on('error', onError); 
server.on('listening', onListening); 

/** 
* Normalize a port into a number, string, or false. 
*/ 

function normalizePort(val) { 
    var port = parseInt(val, 10); 

    if (isNaN(port)) { 
    // named pipe 
    return val; 
    } 

    if (port >= 0) { 
    // port number 
    return port; 
    } 

    return false; 
} 

/** 
* Event listener for HTTP server "error" event. 
*/ 

function onError(error) { 
    if (error.syscall !== 'listen') { 
    throw error; 
    } 

    var bind = typeof port === 'string' 
    ? 'Pipe ' + port 
    : 'Port ' + port; 

    // handle specific listen errors with friendly messages 
    switch (error.code) { 
    case 'EACCES': 
     console.error(bind + ' requires elevated privileges'); 
     process.exit(1); 
     break; 
    case 'EADDRINUSE': 
     console.error(bind + ' is already in use'); 
     process.exit(1); 
     break; 
    default: 
     throw error; 
    } 
} 

/** 
* Event listener for HTTP server "listening" event. 
*/ 

function onListening() { 
    var addr = server.address(); 
    var bind = typeof addr === 'string' 
    ? 'pipe ' + addr 
    : 'port ' + addr.port; 
    debug('Listening on ' + bind); 
} 

回答

0

我最终使用webpack捆绑我的应用程序,并在我的服务器索引中包含bundle.js脚本文件。这使我可以通过localhost:3000显示我的Angular应用程序。

2

您可以使用Github上的页面,Netlify,时代周报现在CLI,或许多其他这些服务允许您在没有后端配置的情况下部署前端应用程序。你为什么选择Heroku?

+0

我读过Github页面只支持静态javascript和jquery页面,而不是Angular应用程序。这是不准确的?我想我一直在尝试Heroku,除了它是一项免费服务,也是我唯一知道的(除了github页面之外)。他们的客户支持也是体面的。无论如何,我想知道如何将前端连接到后端端口可能是有用的。 – sharedev

+0

我强烈建议你使用Zeit的Now CLI。它免费用于OSS并且非常易于使用。 – Alacritas

+1

@sharedev是的,这是不准确的。您绝对可以在Github Pages上托管一个Angular应用程序。将您的应用连接到其他服务需要CORS权限等。 – ThisClark

相关问题