gpt4 book ai didi

javascript - 从函数传递链接时,AngularJS 无法正确路由

转载 作者:行者123 更新时间:2023-11-29 21:25:28 24 4
gpt4 key购买 nike

我正在学习 Angular,所以这是我的测试应用程序:http://enrolin.in/test/#/students

现在我想按名称搜索数据库。所以我创建了 php 来返回我所需要的。这是 php:http://enrolin.in/test/login.php?p=fetchbyname&&name=ak您必须将 url 中的名称替换为您需要搜索的任何内容。我还创建了一个返回绝对正确结果的部分页面,页面如下:http://enrolin.in/test/#/studentSearch/ak到现在为止一切都很好但是问题来了:

当我尝试在 http://enrolin.in/test/#/students 中搜索时, angularJS 不会将我路由到类似 http://enrolin.in/test/#/studentSearch/ak 的地方而是我在 $routeProvider 中设置的默认值

这是我的angularJS(我删除了一些不重要的代码):

var app = angular
.module("Demo", ["ngRoute"])
.config(function ($routeProvider) {
$routeProvider


.when("/students/:id", {
templateUrl: "templates/studentDetails.html",
controller: "studentDetailsController"
})
.when("/studentSearch/:name", {
templateUrl: "templates/studentSearch.html",
controller: "studentSearchController"
})
.otherwise({
redirectTo: "/home"
})

})

.controller("studentDetailsController", function ($scope, $http, $routeParams) {
$http({
url: "http://enrolin.in/test/login.php?p=fetchone&&id=",
method: "get",
params: { id: $routeParams.id }
}).then(function (response) {
$scope.stud = response.data;

})
})
.controller("studentsController", function ($scope, $http, $route,$location) {
$scope.searchStudent=function(){
if($scope.name){
$location.url("/studentsSearch/" + $scope.name);
}
else{
$location.url("/studentsSearch/");
}
}

$scope.reloadData=function(){
$route.reload();
}
$http.get("http://enrolin.in/test/login.php?p=fetchall")
.then(function (response) {
$scope.students = response.data;
})
})
.controller("studentSearchController", function ($scope, $http, $routeParams) {
if($routeParams.name)
{
$http({
url: "http://enrolin.in/test/login.php?p=fetchbyname&&name=",
method: "get",
params: { name: $routeParams.name }
}).then(function (response) {
$scope.studs = response.data;

})
}
else
{
$http.get("http://enrolin.in/test/login.php?p=fetchall")
.then(function (response) {
$scope.students = response.data;
})
}
})

以前每次我想在 html 中放置一个链接来路由时,我都写成 <a href="#/courses">courses</a>但是现在当我想把它放在函数中时,我不知道该写什么。请帮忙。

最佳答案

我认为您可以使用 window.location.href 而不是标签来重定向。或者你可以在 func 中使用“哈希状态”来控制你的路由器

关于javascript - 从函数传递链接时,AngularJS 无法正确路由,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37561638/

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