Nik*_*Nik 4 node.js express angularjs
我知道这个问题有答案,但他们并没有完全为我工作.我正在使用Angular 1.4和Express 4. Express正在处理API调用,而Angular应该处理所有HTML.
我的快递app.js:
var express = require('express');
var path = require('path');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
require('./routes/api')(app);
var app = express();
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, '../client')));
// This covers serving up the index page
app.use(express.static(path.join(__dirname, '../client/.tmp')));
app.use(express.static(path.join(__dirname, '../client/app')));
app.all('*', function(req, res) {
res.redirect('/index.html');
});
module.exports = app;
Run Code Online (Sandbox Code Playgroud)
这是angular app.js
angular
.module('punyioApp', [
'ngAnimate',
'ngAria',
'ngCookies',
'ngMessages',
'ngResource',
'ngRoute',
'ngSanitize',
'ngTouch'
])
.config(function ($routeProvider, $locationProvider) {
$routeProvider
.when('/', {
templateUrl: 'views/main.html',
controller: 'MainCtrl',
controllerAs: 'main'
})
.when('/howitworks', {
templateUrl: 'views/howitworks.html',
controller: 'HowItWorksCtrl',
controllerAs: 'howitworks'
})
.otherwise({
redirectTo: '/'
});
$locationProvider.html5Mode(true);
});
Run Code Online (Sandbox Code Playgroud)
现在,如果我转到http:// localhost:3000 /,我会按预期获得主要的Angular视图.问题是当我转到http:// localhost:3000/howitworks,它将我重定向到http:// localhost:3000/index.html并且不显示'howitworks'视图.如何修复快速路由器以便我可以访问http:// localhost:3000/howitworks?
Pie*_*eau 13
您的代码只是将每个请求重定向到index.html
,这不是您想要的.你确实需要那个文件,但是由于Angular处理路由,你只需要Express发送文件,不要问任何问题.
基本上,你不应该使用redirect
,但是sendFile
:
app.get('/*', function(req, res) {
res.sendFile(__dirname + '/index.html')
});
Run Code Online (Sandbox Code Playgroud)
此外,正如有人在评论中指出的那样,你应该使用get
而不是all
.
归档时间: |
|
查看次数: |
3761 次 |
最近记录: |