如何将搜索ID发送到`$ resource` prodiver?

时间:2015-07-23 12:29:58

标签: angularjs angular-routing

当用户舔元素时,我正在更改搜索参数。更新我的搜索参数后,我的网址位置改为:

http://localhost:3000/#/projectSummary/1?id=3

现在如何发送这样的$routeParamshttp://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')

            }

        }]);

})();

1 个答案:

答案 0 :(得分:2)

您需要为2个不同的参数配置$ resource。

现在你在网址中使用了两次相同的参数,因此无法将对象密钥解析为2个不同的

应该更像是:

// factory
contractor : $resource( base + 'projects/:id/:contid')

// controller
server.contractor.get({id:$routeParams.id, contid:contractor.Id})