【发布时间】:2015-08-19 18:35:35
【问题描述】:
我有一个看起来像这样的订单资源。
.factory('Order', order)
order.$inject = ['$resource', "ApiEndpoint"];
function order($resource, ApiEndpoint) {
return $resource(ApiEndpoint.url + 'orders.json', {}, {
create: {method: 'POST', url: ApiEndpoint.url + 'orders.json'},
update: {method: 'PUT'},
edit: {method: 'GET', url: ApiEndpoint.url + 'orders/edit.json'},
remove_item: {method: 'GET', url: ApiEndpoint.url + 'orders/remove_item.json'},
});
}
当我像这样运行Order.update 时
var params = {
order: {
line_items_attributes: {0: {quantity: 2, id: 1}}
},
order_id: 3
};
Order.update(params, function (resp, respHeaders) {
console.log("response headers", respHeaders());
console.log("change quantity resp", resp);
})
我也试过这个:
Order.update({}, params, function (resp, respHeaders) {
console.log("response headers", respHeaders());
console.log("change quantity resp", resp);
})
发送到服务器的参数最终位于 URL 内。例如,这是服务器收到的 url 之一
path="/api/mobile/orders.json?order=%7B%22line_items_attributes%22:%7B%220%22:%7B%22quantity%22:8,%22id%22:356265%7D%7D%7D"
我还应该注意,服务器接收到的方法是OPTIONS 请求。服务器已设置为处理此问题。
既然我正在发送 PUT 请求,为什么 $resource 通过 URL 传递参数而不是负载的一部分?
【问题讨论】:
标签: angularjs http params put angular-resource