ホームページ > ウェブフロントエンド > jsチュートリアル > jQuery の AJAX メソッドを使用して画像を BLOB として取得するにはどうすればよいですか?

jQuery の AJAX メソッドを使用して画像を BLOB として取得するにはどうすればよいですか?

Barbara Streisand
リリース: 2024-11-12 13:36:02
オリジナル
190 人が閲覧しました

How to Retrieve Images as Blobs Using jQuery's AJAX Method?

jQuery の AJAX メソッドを使用して画像を BLOB として取得する

jQuery の AJAX メソッドを使用して画像を BLOB として取得することは、受け入れられるデータ型として直接サポートされていません。画像形式は含まれません。この不一致により、画像が破損することがよくあります。

この制限を克服するには、jQuery の AJAX メソッドの代わりにネイティブ XMLHttpRequest を利用できます。このアプローチにより、responseType を明示的に 'blob' に設定できます:

var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function() {
  if (this.readyState == 4 && this.status == 200) {
    handler(this.response);
    var img = document.getElementById('img');
    var url = window.URL || window.webkitURL;
    img.src = url.createObjectURL(this.response);
  }
};
xhr.open('GET', 'http://jsfiddle.net/img/logo.png');
xhr.responseType = 'blob';
xhr.send();
ログイン後にコピー

また、jQuery バージョン 3 では、画像を blob として取得できるようになります:

jQuery.ajax({
  url: 'https://images.unsplash.com/...',
  cache: false,
  xhr: function() {
    var xhr = new XMLHttpRequest();
    xhr.responseType = 'blob';
    return xhr;
  },
  success: function(data) {
    var img = document.getElementById('img');
    var url = window.URL || window.webkitURL;
    img.src = url.createObjectURL(data);
  },
  error: function() {}
});
ログイン後にコピー

これを利用するこのアプローチを使用すると、画像を BLOB として効率的に取得し、その後 POST リクエストで別のサーバーにアップロードするなどの操作を実行できます。

以上がjQuery の AJAX メソッドを使用して画像を BLOB として取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート