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

希望我帮忙

相关文章

页面搜索关键词突出 // 页面搜索关键词突出 $(function () {...
jQuery实时显示日期、时间 html: &lt;span id=&quot...
jQuery 添加水印 &lt;script src=&quot;../../../.....
中文:Sys.WebForms.PageRequestManagerParserErrorExceptio...
1. 用Response.Write方法 代码如下: Response.Write(&q...
Jquery实现按钮点击遮罩加载,处理完后恢复 思路: 1.点击按...