vue播放鏈接音頻

問(wèn)題

前端一般播放音頻都是通過(guò)鏈接播放,這個(gè)鏈接一般是后端接口返回,于安全考慮,后端不應(yīng)該向外部返回可用鏈接。
那么另外一種思路就是先通過(guò)接口下載好音頻文件,再播放

代碼

需要注意的是
1、異步請(qǐng)求
2、使用xhr的方式
3、返回類型為blob,通過(guò)【window.URL.createObjectURL】方法創(chuàng)建臨時(shí)可播放文件
4、使用audio標(biāo)簽播放

play: async function () {
            const xhr = new XMLHttpRequest();
            const url = 'XXX接口地址';
            // 設(shè)置請(qǐng)求方式POST方式
            xhr.open('POST', url, true);
            // 返回類型blob
            xhr.responseType = "arraybuffer";
            xhr.setRequestHeader("Content-Type", "application/json");
            xhr.send();
            xhr.onload = function () {
                const content = this.response; //獲取后臺(tái)響應(yīng)內(nèi)容
                alert(content);
                const wavBlob = new Blob([content], {type: 'audio/wav'});
                const audio = document.getElementById('audio');
                alert(audio);
                audio.src = window.URL.createObjectURL(wavBlob);
                alert(audio.src);
                audio.play();
            }
        }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容