我是angularJS的新手,我喜歡用它編碼。我目前正在使用angularJS構建一個門戶網站,並且我的每個網頁都使用ngRoute
。它適用於我,但當我嘗試刷新頁面時,它返回了我的404 error/page not found
。我應該在這個問題上做什麼?這裏是我的代碼:當頁面刷新時,AngularJS路由返回404錯誤
var app = angular.module("CVSRRC", ['ngMaterial','ngRoute']);
app.controller('CVSRRC-CTRL', function($scope, $http, ...){
// some codes here...
});
app.config(function($routeProvider, $locationProvider){
$locationProvider.html5Mode(true).hashPrefix('!');
$routeProvider
.when('/', {
templateUrl: '_pages/home',
controller: 'homeCTRL',
resolve: {
delay: function($q, $timeout){
var delay = $q.defer();
$timeout(delay.resolve, 1000);
return delay.promise;
}
}
})
...etc...
.otherwise({
redirectTo: '/'
});
});
,並在我的HTML
<html>
<head>
<base href="/cvsrrc/" />
</head>
<body ng-app="CVSRRC" ng-controller="CVSRRC-CTRL">
<div class="row" id="main">
<div ng-view ng-show="statechange"></div>
<div ng-show="!statechange" cvsrrc-resolve>
<div id="_loader_"></div>
</div>
</div>
<a href="about-us">About</a>
<a href="login">login</a>
//etc
</body>
</html>
而且這裏是我的.htaccess看起來像
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^([^\.]+)$ $1.php [NC,L]
ErrorDocument 404 http://localhost/cvsrrc/page-not-found
所以我會配置它到我的.htaccess你的意思是? Sir @Ankur Akvaliya –
是的。取決於後端。我想你正在使用PHP。 –
你可以查看這裏-http://stackoverflow.com/questions/38291535/page-refresh-gives-404你可以通過這個去了解更多有趣的東西來閱讀有關angularjs中html5模式和每個不同環境所需的配置https://github.com/angular-ui/ui-router/wiki/Frequently-Asked-Questions#how-to-configure-your-server-to-work-with-html5mode另外這個問題可能會幫助你$ location /切換html5和hashbang模式/鏈接重寫 –