gpt4 book ai didi

node.js - Angular Ui-Router 在使用 node.js 时没有路由

转载 作者:搜寻专家 更新时间:2023-10-31 22:24:25 25 4
gpt4 key购买 nike

我正在使用 Angular ui 路由器。路由器在主页 index.html 上似乎运行良好。但是任何其他导航都不起作用。

这是我的状态提供者 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"
})
;
});

我的主要 index.html 中的 HTML:

 <!--Content -->
<div class="container">
<div ui-view></div>
</div>
<!-- END Content -->

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

enter image description here如果找不到它,我想我什至不应该看到这个页面。由于 $urlRouterProvider.otherwise(),它不应该将我重定向回“/”吗?除此之外,尽管模板 url/partials/account/login.html 确实存在。

我对 node.js 有点陌生,我很好奇笔记文件服务器是否正在尝试路由并胜过我的 angular.service 器?我正在使用 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;

最佳答案

我想通了。执行以下操作使其工作。

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.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;

当然这需要在你的 Angular 代码中:

app.config(["$locationProvider", function($locationProvider) {
$locationProvider.html5Mode(true);
}]);

有一件事让我印象深刻。您必须重新启动服务器才能使其生效。 ctr+c 然后粘贴此代码然后重新启动服务器。祝你好运

关于node.js - Angular Ui-Router 在使用 node.js 时没有路由,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24072474/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com