javascript-jQuery.ajax仅*检索状态代码,而不检索/下载整个文档?
作者:互联网
我有一个使用jQuery.ajax轮询资源以查明是否存在的应用程序. (在后台有一个服务正在生成资源).当资源不再提供404状态时,我的应用程序将重定向到该资源以供查看.我的问题是…可以在不下载文档的全部内容的情况下获得状态吗?如果要轮询的PDF很大,恐怕获取200的状态并通过jquery下载该文档,然后将其丢弃并重定向到有问题的文档,效率会很低.
这是我在做什么(咖啡):
class PDFPoller
constructor: (@url) ->
pollForPDF: ->
@timeout = setTimeout(@poll, 3000)
poll: =>
jQuery.ajax(@url, complete: @verifyPDF)
verifyPDF: (jqXHR, textStatus) =>
console.log jqXHR.status
if jqXHR.status != 404
window.location = @url
else
@pollForPDF()
@isGeneratingPDF: ->
$(".js_pdf_gen_notice").length > 0
@events: =>
if @isGeneratingPDF()
poller = new PDFPoller($(".js_pdf_gen_notice").data('url'))
poller.pollForPDF()
$(document).on 'ready', ->
PDFPoller.events()
解决方法:
您不仅可以获得状态码,还可以仅请求HTTP标头.
使用HEAD方法.然后,您可以检查jqXHR对象的状态.
jQuery.ajax("/", { type: "HEAD"}).done(
function (data, textStatus, jqXHR) {
console.log(jqXHR.status);
}
);
标签:ajax,coffeescript,http-status-codes,javascript,jquery 来源: https://codeday.me/bug/20191122/2058449.html