jQuery $.ajax或$.load是否允许responseType arrayBuffer?

前端之家收集整理的这篇文章主要介绍了jQuery $.ajax或$.load是否允许responseType arrayBuffer?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我开始使用Web Audio API,只是想知道是否可以使用jQuery的$ .ajax或$ .load函数来创建接收音频数据的XMLHttpRequest。 do $ .ajax或$ .load支持responseType = arrayBuffer?

编辑:

好的,所以这里是我到目前为止

function loadAudio() {
    $.ajax({
            url: sourceUrl
        }).done(function(response){
            return response;
        })
    }

但是我需要返回一个ArrayBuffer。那么如何将响应转换为ArrayBuffer?

解决方法

关于你的问题,似乎jQuery还不支持它。在使用之前,如下所述,请考虑检查该功能是否可用。

使用XHTMLRequest,您可以欺骗您的服务器并从服务器接收表示所需字节的二进制字符串。它工作完美。

var xhr = new XMLHttpRequest();
xhr.open('GET','/your/audio/file.wav',true);

// Here is the hack
xhr.overrideMimeType('text/plain; charset=x-user-defined');

xhr.onreadystatechange = function(event) {
  if ( this.readyState == 4 && this.status == 200 ) {
    var binaryString = this.responseText;

    for (var i = 0,len = binaryString.length; i < len; ++i) {
      var c = binaryString.charCodeAt(i);
      var byte = c & 0xff; //it gives you the byte at i
      //Do your cool stuff...

    }
  }
};

xhr.send();

它的作品,它是常见的…但它仍然是一个黑客。

使用XHTML请求级别2,可以将responseType指定为“arraybuffer”并实际接收ArrayBuffer。这是更好的问题是检查您的浏览器是否支持功能

var xhr = new XMLHttpRequest();
xhr.open('GET',true);
xhr.responseType = 'arraybuffer';

xhr.onload = function(e) {
  if (this.status == 200) {
    //Do your stuff here
  }
};

xhr.send();

希望我帮忙

原文链接:https://www.f2er.com/jquery/182133.html

猜你在找的jQuery相关文章