使用node.js时,Angular Ui-Router不进行路由

all*_*ded 7 node.js angularjs angular-routing

我正在使用角度ui路由器.路由器似乎在主页index.html上运行完美.但任何其他导航都不起作用.

这是我的stateprovider angular:

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"
        })
    ;
});
Run Code Online (Sandbox Code Playgroud)

主要index.html中的HTML:

 <!--Content -->
    <div class="container">
        <div ui-view></div>
    </div>
    <!-- END Content -->
Run Code Online (Sandbox Code Playgroud)

当我浏览localhost:8080/login页面时,我得到了这个:

在此输入图像描述 如果它找不到,我想我甚至不应该看到这个页面.由于$ urlRouterProvider.otherwise(),它不应该将我重定向回"/".除此之外,模板url /partials/account/login.html存在.

我对node.js有些新意,我很好奇,如果笔记文件服务器试图路由并打败我的角度文件服务器?我使用的是http-server,这可能是最常见的.

如果有帮助,我也在使用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;
Run Code Online (Sandbox Code Playgroud)

all*_*ded 4

我想到了。执行以下操作使其有效。

app.use(function(req, res) {
    // Use res.sendfile, as it streams instead of reading the file into memory.
    res.sendfile(__dirname + '/public/index.html');
});
Run Code Online (Sandbox Code Playgroud)

整个 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 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(function(req, res) {
    // Use res.sendfile, as it streams instead of reading the file into memory.
    res.sendfile(__dirname + '/public/index.html');
});

app.use('/', routes);



/// 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;
Run Code Online (Sandbox Code Playgroud)

当然,这需要在你的角度代码中:

app.config(["$locationProvider", function($locationProvider) {
    $locationProvider.html5Mode(true);
}]);
Run Code Online (Sandbox Code Playgroud)

有一件事让我注意到。您必须重新启动服务器才能使其工作。ctr+c 然后粘贴此代码然后重新启动服务器。祝你好运