微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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.jb51.cc/jquery/182133.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐