Я использую маршрутизатор angular ui. Маршрутизатор, кажется, отлично работает на домашней странице index.html. Но никакая другая навигация не работает.
Вот мой stateprovider угловой:
var app = angular.module('myApp', ['ui.router']);
app.config(function($stateProvider, $urlRouterProvider) {
$urlRouterProvider.otherwise("/");
$stateProvider
.state("home", {
url: "/",
templateUrl: "../partials/home/index.html"
})
.state("login", {
url:"/login",
templateUrl: "../partials/account/login.html"
})
.state("register", {
url: "/register",
templateUrl: "../partials/account/register.html"
})
.state("values", {
url: "/values",
templateUrl: "../partials/test/values.html"
})
;
});
HTML в моем основном index.html:
<!--Content -->
<div class="container">
<div ui-view></div>
</div>
<!-- END Content -->
Когда я перехожу по странице localhost:8080/login, я получаю следующее:
Я думаю, что даже не должен видеть эту страницу, если он не может ее найти. Разве это не должно перенаправить меня обратно на «/» из-за $urlRouterProvider.otherwise(). Помимо этого, хотя URL-адрес шаблона /partials/account/login.html существует.
Я новичок в node.js, и мне любопытно, пытается ли файловый сервер заметок маршрутизировать и превосходить мой угловой? Я использую http-сервер, который, вероятно, является наиболее распространенным.
Я также использую Express Node, если это помогает. И вот код для app.js, где, я думаю, может возникнуть проблема:
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 routes = 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', 'jade');
app.use(favicon());
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', routes);
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 handlers
// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
app.use(function(err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: err
});
});
}
// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: {}
});
});
module.exports = app;