登录

javascript - jquery的ajax的返回资源类型没有arraybuffer?

跟着网上的视频写的demo,老师是用js写的,我想改用jquery,但是ajax这里有问题

$.ajax({url:"/medias/"+this.title,
            type : "GET",
            dataType : "arraybuffer",
            success : function(data){
                console.log(typeof(data));
                ac.decodeAudioData(data,function(buffer){
                    var bufferSource = sc.createbufferSource();
                    bufferSource.buffer = buffer;
                    bufferSource.connect(ac.destination);
                    bufferSource[bufferSource.start?"start":"noteOn"](0);
                    console.log("starting");
                },
                function(err){
                    console.log(err);
                });
            },
            error : function(data,err){
                console.log(err);
            }
        });

打印出来得error信息是 “parsererror”,如何解决?

# JavaScript
阿神阿神2184 天前616 次浏览

全部回复(1) 我要回复

  • ringa_lee

    ringa_lee2017-04-10 14:55:13

    jq中ajax可用的datatype是预定义好的,有如下几种:

    • xml
    • html
    • script
    • json
    • jsonp
    • text

    如果你需要传递arraybuffer数据,可以使用text,然后手动parse。


    update
    mmmm……试试看这个。

    js// 字符串转为ArrayBuffer对象,参数为字符串
    function str2ab(str) {
        var buf = new ArrayBuffer(str.length*2); // 每个字符占用2个字节
        var bufView = new Uint16Array(buf);
        for (var i=0, strLen=str.length; i<strLen; i++) {
             bufView[i] = str.charCodeAt(i);
        }
        return buf;
    }
    

    仔细想了想,ajax是基于xhr第一版本的,而ArrayBuffer是基于xhr第二版本的,这个意义上其实最好还是用原生代码省心……

    回复
    0
  • 取消回复发送