gpt4 book ai didi

javascript - Angular $routeProvider 不适用于 Apache 服务器

转载 作者:行者123 更新时间:2023-11-28 07:20:26 25 4
gpt4 key购买 nike

我现在正在吃这个泡菜。我正在 Linux 上使用 Apache 服务器在本地(localhost)运行这个 Angular 前端。当我尝试访问本地主机时,一切正常,我得到了我的index.html。但现在我在 index.html 中有一个链接,它应该将用户重定向到 localhost/users。但我似乎无法让它发挥作用,我已经尝试了所有解决方案,但似乎没有任何效果。也许你们中的一些人看到我做错了什么?

我的app.js

(function() {
var app = angular.module('linkrec', ['ngRoute']);

app.config(function($routeProvider, $locationProvider) {
$locationProvider.html5mode(true).hashPrefix('!');
$routeProvider

.when('/users', {
templateUrl: '/users.html',
});
});


app.controller('UsersController', [ '$http', function($http) {
var linkrec = this;
linkrec.users = [];

$http.get('https://localhost:9443/users').success(function(data){
linkrec.users = data;
});
} ]);

})();

我的index.html

<!DOCTYPE <!DOCTYPE html>
<html ng-app="linkrec">
<head>
<title>LinkRec</title>
<link rel="stylesheet" type="text/css" href="bootstrap/css/bootstrap.min.css">
<link rel="stylesheet" type="text/css" href="linkrec.css">
</head>
<body>
<script type="text/javascript" src="node_modules/angular/angular.js"></script>
<script type="text/javascript" src="node_modules/angular/angular-route.js"></script>
<script type="text/javascript" src="app.js"></script>

<h1>LinkRec</h1>
<div class="container" ng-view>
<a href="/users"><h2>Users</h2></a>
<h2>Vacancies</h2>
<h2>Groups</h2>
</div>

</body>
</html>

我的 .htaccess 曾经是

<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*) /index.html/#!/$1
</IfModule>

现在我的.htaccess

# Apache .htaccess

# angularjs pushstate (history) support:
# See http://www.josscrowcroft.com/2012/code/htaccess-for-html5-history-pushstate-url/
FallbackResource /index.html

有人发现我的错误吗? Angular 文件在那里并且链接正确。提前致谢。

最佳答案

(我会发表评论,因为我不能 100% 确定我的答案,但我的代表太低)

我发现您已打开 html5 模式,因此我认为您的 .htaccess 文件未正确调整为此。

尝试以下 .htaccess 代码

<IfModule mod_rewrite.c>
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^ index.html [L]
</IfModule>

关于javascript - Angular $routeProvider 不适用于 Apache 服务器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30376186/

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