编程语言
首页 > 编程语言> > javascript-jQuery.ajax仅*检索状态代码,而不检索/下载整个文档?

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