当前位置: 首页 > 面试题库 >

使用jQuery的ajax方法作为blob检索图像

段干宜
2023-03-14
问题内容

我最近问了另一个(相关的)问题,这导致了后续问题:

通读jQuery.ajax()文档(http://api.jquery.com/jQuery.ajax/),似乎可接受的dataTypes列表不包含图像。

我正在尝试使用jQuery.get(如果需要的话,也可以使用jQuery.ajax)来检索图像,将此图像存储在Blob中,然后在POST请求中将其上传到另一台服务器。当前,由于数据类型不匹配,我的图像最终被损坏(字节大小不匹配等)。

执行此操作的代码如下(它在coffeescript中,但应该不难解析):

handler = (data,status) ->
  fd = new FormData
  fd.append("file", new Blob([data], { "type" : "image/png" }))
  jQuery.ajax {
    url: target_url,
    data: fd,
    processData: false,
    contentType: "multipart/form-data",
    type: "POST",
    complete: (xhr,status) ->
      console.log xhr.status
      console.log xhr.statusCode
      console.log xhr.responseText

  }
jQuery.get(image_source_url, null, handler)

我如何检索此图像作为blob?


问题答案:

您不能使用jQuery ajax来执行此操作,而是使用本机XMLHttpRequest来执行此操作。

var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function(){
    if (this.readyState == 4 && this.status == 200){
        //this.response is what you're looking for
        handler(this.response);
        console.log(this.response, typeof 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做到这一点。

jQuery.ajax({

        url:'https://images.unsplash.com/photo-1465101108990-e5eac17cf76d?ixlib=rb-0.3.5&q=85&fm=jpg&crop=entropy&cs=srgb&ixid=eyJhcHBfaWQiOjE0NTg5fQ%3D%3D&s=471ae675a6140db97fea32b55781479e',

        cache:false,

        xhr:function(){// Seems like the only way to get access to the xhr object

            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(){



        }

    });


<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js"></script>

<img id="img" width=100%>

要么

使用xhrFields设置responseType

    jQuery.ajax({

            url:'https://images.unsplash.com/photo-1465101108990-e5eac17cf76d?ixlib=rb-0.3.5&q=85&fm=jpg&crop=entropy&cs=srgb&ixid=eyJhcHBfaWQiOjE0NTg5fQ%3D%3D&s=471ae675a6140db97fea32b55781479e',

            cache:false,

            xhrFields:{

                responseType: 'blob'

            },

            success: function(data){

                var img = document.getElementById('img');

                var url = window.URL || window.webkitURL;

                img.src = url.createObjectURL(data);

            },

            error:function(){



            }

        });


<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js"></script>

    <img id="img" width=100%>


 类似资料:
  • 问题内容: :我只想显示Mysql表记录的简单ajax代码: Records.php是用于从Mysql提取记录的文件。 在数据库中只有两个字段:“名称”,“地址”。 该代码不起作用。 问题答案: 为了使用Ajax + jQuery检索数据,您应该编写以下代码: 对于mysqli连接,请编写以下代码: 为了显示数据库中的数据,您应该这样编写:

  • 问题内容: 我旁边有一个文本框和一个按钮。我想通过对webmethod的Jquery ajax调用发送文本框的内容,并获取相同的大写值并将其显示在警报中。到目前为止,我有此代码,但无法正常工作。 JAVASCRIPT: HTML: 网页方法: 问题答案: 根据您的评论,我了解您的问题尚未解决,所以只需尝试一下

  • 我使用ExtJS来执行AJAX请求。这是我的密码 所以我决定从servlet获取请求参数。所以我使用了 但是我得到一个空值。当我使用POST方法时,它工作得很好,但不是PUT。在使用 PUT 方法时,有没有其他方法可以在 servlet 中获取请求参数?

  • 本文向大家介绍Jquery的Ajax技术使用方法,包括了Jquery的Ajax技术使用方法的使用技巧和注意事项,需要的朋友参考一下 Jquery的Ajax技术(重点) jquery是一个优秀的js框架,自然对js原生的ajax进行了封装,封装后的ajax的操作方法更简洁,功能更强大,与ajax操作相关的jquery方法有如下几种,但开发中经常使用的有三种: 1)$.get(url, [data],

  • 本文向大家介绍jQuery Ajax()方法使用指南,包括了jQuery Ajax()方法使用指南的使用技巧和注意事项,需要的朋友参考一下  jQuery提供了简单而强大的选择器功能,同时对Ajax操作也给出了很好的支持。在Ajax方面,jQuery除了提供底层的jQuery.ajax()方法外,也提供了下面的简单方法: (1)       jQuery.get(url, [data], [cal

  • 本文向大家介绍Jquery操作Ajax方法小结,包括了Jquery操作Ajax方法小结的使用技巧和注意事项,需要的朋友参考一下 ajax() 方法通过 HTTP 请求加载远程数据。 该方法是 jQuery 底层 AJAX 实现。简单易用的高层实现见 $.get, $.post 等。$.ajax() 返回其创建的 XMLHttpRequest 对象。大多数情况下你无需直接操作该函数,除非你需要操作不