用了ui-router地址栏没有#, 切换路由后视图也能切换,但是一刷新就Cannot GET

路由配置如下:

states: [
            {
                name: "app",
                data: {
                    url: '/',
                    views: {
                        'header': {
                            templateUrl: '/views/common/header.html',
                            controller: null
                        },
                        'content': {
                            templateUrl: '/views/common/content.html',
                            controller: null
                        },
                        'footer': {
                            templateUrl: '/views/common/footer.html',
                            controller: null
                        }
                    }
                }
            },
            {
                name: "app.about",
                data: {
                    url: 'about',
                    views: {
                        'content@': {
                            templateUrl: '/views/about.html',
                            controller: null
                        }
                    }
                }
            },
            {
                name: "app.contact",
                data: {
                    url: 'contact',
                    views: {
                        'content@': {
                            templateUrl: '/views/contact.html',
                            controller: null
                        }
                    }
                }
            }
        ]
        

index.html主要如下:

<div ui-view="header"></div>
<div ui-view="content"></div>
<div ui-view="footer"></div>

header.html里是两个路由

 <a ui-sref="app.about">关于我们</a>
 <a ui-sref="app.contact">联系我哈</a>

现在点击app.about 和app.contact都能切换视图, 但是地址栏没有#,一刷新就
Cannot GET

阅读 2.8k
1 个回答

"Cannot GET" 是因为浏览器不知道你是想设置路由,以为你是在执行请求。

试试配置上:$locationProvider.html5Mode(true);

https://docs.angularjs.org/ap...$locationProvider

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题