欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JQuery中模擬image的ajaxPrefilter與ajaxTransport處理

 更新時(shí)間:2015年06月19日 09:15:34   投稿:junjie  
這篇文章主要介紹了JQuery中模擬image的ajaxPrefilter與ajaxTransport處理,本文直接給出模擬實(shí)現(xiàn)代碼,代碼中包含詳細(xì)注釋,需要的朋友可以參考下

//////////////////////////////////////////////////////////////////
  // options 是請(qǐng)求的選項(xiàng)                        //
  // originalOptions 值作為提供給Ajax方法未經(jīng)修改的選項(xiàng),因此,沒(méi)有ajaxSettings設(shè)置中的默認(rèn)值 //
  // jqXHR 是請(qǐng)求的jqXHR對(duì)象                      //
  //////////////////////////////////////////////////////////////////
  $.ajaxPrefilter("image", function(options, originalOptions, jqXHR) {
    //通過(guò)預(yù)處理器轉(zhuǎn)化類型
    if (options.test) {
      options.type = 'GET'
    }
    //增加前綴
    options.url = "http://img.mukewang.com/" + options.url
  });


  ///////////////////////
  // 請(qǐng)求分發(fā)器 transports //
  ///////////////////////
  $.ajaxTransport("image", function(s) {
    if (s.type === "GET" && s.async) {
      var image;
      return {
        send: function(_, callback) {
          image = new Image();
          function done(status) {
            if (image) {
              var statusText = (status == 200) ? "success" : "error",
                tmp = image;
              image = image.onreadystatechange = image.onerror = image.onload = null;
              callback(status, statusText, {
                image: tmp
              });
            }
          }
          image.onreadystatechange = image.onload = function() {
            done(200);
          };
          image.onerror = function() {
            done(404);
          };
          show(s.url)
          image.src = s.url;
        },
        abort: function() {
          if (image) {
            image = image.onreadystatechange = image.onerror = image.onload = null;
          }
        }
      };
    }
  });


  $("#test").click(function(){

     //執(zhí)行一個(gè)異步的HTTP(Ajax)的請(qǐng)求。
    var ajax = $.ajax({
      test   : true, //測(cè)試
      url   : '547d5a45000156f406000338-590-330.jpg',
      dataType : 'image',
      type   : 'POST',
      data: {
        foo: ["bar1", "bar2"]
      },
      //這個(gè)對(duì)象用于設(shè)置Ajax相關(guān)回調(diào)函數(shù)的上下文
      context: document.body,
      //請(qǐng)求發(fā)送前的回調(diào)函數(shù),用來(lái)修改請(qǐng)求發(fā)送前jqXHR
      beforeSend: function(xhr) {
        xhr.overrideMimeType("text/plain; charset=x-user-defined");
        show('局部事件beforeSend')
      },
      //請(qǐng)求完成后回調(diào)函數(shù) (請(qǐng)求success 和 error之后均調(diào)用)
      complete: function() {
        show('局部事件complete')
      },
      error: function() {
        show('局部事件error請(qǐng)求失敗時(shí)調(diào)用此函數(shù)')
      },
      success: function() {
        show('局部事件success')
      }
    })

    ajax.done(function() {
      show('done')
    }).fail(function() {
      show('fail')
    }).always(function() {
      show('always')
    })

您可能感興趣的文章:

相關(guān)文章

最新評(píng)論