У меня есть следующая операция в созданном мной веб-API:
// GET api/<controller>
[HttpGet]
[Route("pharmacies/{pharmacyId}/page/{page}/{filter?}")]
public CartTotalsDTO GetProductsWithHistory(Guid pharmacyId, int page, string filter = null ,[FromUri] bool refresh = false)
{
return delegateHelper.GetProductsWithHistory(CustomerContext.Current.GetContactById(pharmacyId), refresh);
}
Вызов этого веб-сервиса выполняется через вызов JQuery Ajax следующим образом:
$.ajax({
url: "/api/products/pharmacies/<%# Farmacia.PrimaryKeyId.Value.ToString() %>/page/" + vm.currentPage() + "/" + filter,
type: "GET",
dataType: "json",
success: function (result) {
vm.items([]);
var data = result.Products;
vm.totalUnits(result.TotalUnits);
}
});
Я видел, как некоторые разработчики реализуют предыдущую операцию таким образом:
// GET api/<controller>
[HttpGet]
[Route("pharmacies/{pharmacyId}/page/{page}/{filter?}")]
public async Task<CartTotalsDTO> GetProductsWithHistory(Guid pharmacyId, int page, string filter = null ,[FromUri] bool refresh = false)
{
return await Task.Factory.StartNew(() => delegateHelper.GetProductsWithHistory(CustomerContext.Current.GetContactById(pharmacyId), refresh));
}
Однако следует сказать, что GetProductsWithHistory () - довольно долгая операция. Какую пользу мне принесет асинхронная работа webAPI с учетом моей проблемы и контекста?
GetProductsWithHistoryAsync()
возврате Task<CartTotalsDTO>
. Написание асинхронного режима вашего контроллера может оказаться полезным, если вы намереваетесь также перенести выполняемые им вызовы в асинхронные; тогда вы начнете получать выгоду от асинхронных частей по мере переноса остальных.
async Task<T>
. Помните, AJAX был реализован еще до того, как TPL вообще существовала :)