当用户舔元素时,我正在更改搜索参数。更新我的搜索参数后,我的网址位置改为:
http://localhost:3000/#/projectSummary/1?id=3
现在如何发送这样的$routeParams
?http://localhost:3000/#/projectSummary/1/3
这是我的尝试:
$scope.conractorInfo = function ( contractor ) {
$location.search('id', contractor.Id); //setting id
console.log($routeParams.id) //getting `1` not 1/3 !?
server.contractor.get({id:$routeParams.id+'/'+contractor.Id}).$promise.then(function (data) {
console.log(data);
});
}
这是我的server.js
(function () {
"use strict";
angular
.module("tcpApp")
.factory("server", ['$resource', function ($resource) {
var base = 'http://azvsptcsdev02:678/_vti_bin/CPMD.WEBSERVICE/ProjectInfoService.svc/';
console.log(base + 'GetProjectDetails')
return {
splash : $resource( base + 'GetProjectDetails'),
summary : $resource( base + 'GetProjectByID/:id'),
contractor : $resource( base + 'projects/:id/:id')
}
}]);
})();
答案 0 :(得分:2)
您需要为2个不同的参数配置$ resource。
现在你在网址中使用了两次相同的参数,因此无法将对象密钥解析为2个不同的
应该更像是:
// factory
contractor : $resource( base + 'projects/:id/:contid')
// controller
server.contractor.get({id:$routeParams.id, contid:contractor.Id})