如何在使用ui-router时获得漂亮的URL(删除#)。

时间:2017-03-23 17:28:58

标签: angularjs express angular-ui-router

我已经在我的index.html文件的头部尝试了$ locationProvider和base href标记。但是在渲染我的视图时出现了404错误。我认为这是app.js文件中Express的app.use方法。

这是我这个项目的文件夹结构。 https://i.stack.imgur.com/PFPlk.png

这是我的app.js文件。

var express = require('express');
var app = express();
app.use(express.static(__dirname+'/public'));
app.listen(3000);
console.log('Running on port 3000...');

这是我的script.js文件。

var myApp = angular.module('myApp', ['ui.router']);
myApp.config(function($stateProvider,$urlRouterProvider) {
$stateProvider
    .state('home', {
    url: '/',
    templateUrl : 'views/home.html',
    controller  : 'homeController'
})
    .state('posts', {
    url: '/posts',
    templateUrl : 'views/posts.html',
    controller  : 'postsController'
})
    .state('radio', {
    url: '/radio',
    templateUrl : 'views/radio.html',
    controller  : 'radioController'
});
$urlRouterProvider.otherwise('/');
});
myApp.controller('homeController', function($scope) { 
$scope.title = 'Hello.'; 
});
myApp.controller('radioController', function($scope) { 
$scope.message = 'Look! I am an radio page.'; 
});

这是我的index.html文件。

<!DOCTYPE html>
<html lang="en">
<head>
    <title>WISS</title>
    <link rel="stylesheet" href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css" />
    <link rel="stylesheet" href="styles/styles.css" />
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.25/angular.min.js"></script>
    <script src="//ajax.googleapis.com/ajax/libs/angularjs/1.2.25/angular-route.js"></script>
    <script src="//cdnjs.cloudflare.com/ajax/libs/angular-ui-router/0.2.8/angular-ui-router.min.js"></script>
    <script src="script.js"></script>
</head>
<body ng-app="myApp">
        <nav class="navbar navbar-inverse navbar-fixed-top">
            <div class="container-fluid">
                <div class="navbar-header">
                    <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1" aria-expanded="false">
                        <span class="sr-only">Toggle navigation</span>
                        <span class="icon-bar"></span>
                        <span class="icon-bar"></span>
                        <span class="icon-bar"></span>
                    </button>
                    <a class="navbar-brand" href="/">Brand</a>
                </div>
                <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
                    <ul class="nav navbar-nav navbar-right">
                        <li><a ui-sref="home">HOME</a></li>
                        <li><a ui-sref="posts">POSTS</a></li>
                        <li><a ui-sref="radio">RADIO</a></li>
                    </ul>
                </div>
            </div>
        </nav>
    <div class="container">
        <div id="main">
            <div ui-view></div>
        </div>
    </div>
</body>
</html>

1 个答案:

答案 0 :(得分:-1)

$locationProvider.html5Mode(true);区块的角色位置myApp.config

然后快递在app.listen(3000)

之前添加
app.all('/*', function(req, res) {
    res.sendfile('public/index.html');
});