您好,登錄后才能下訂單哦!
本篇內容主要講解“HTML5 Video/Audio播放本地文件的方法”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“HTML5 Video/Audio播放本地文件的方法”吧!
在得到用戶允許后我們還是可以播放本地文件的,在頁面中插入一個input節點并指定type為file,然后把該url設置為audio或video的src值即可
這段時間經常看到開發者在反復詢問同一個問題,為什么通過設置src屬性,不能播放本地的媒體文件?例如video.src=”D:/test.mp4”。
這是因為瀏覽器中的JavaScript不能直接直接訪問本地資源(例如文件系統,攝像頭,麥克風等),除非事先得到了用戶的允許。瀏覽器之所以進行該限制也是很有必要的,試想一下,如果JavaScript能夠肆無忌憚的訪問本地的文件系統,那么竊取用戶隱私數據就變得輕而易舉了,當用戶訪問網絡上的某個網頁時,不知不覺中自己機器上保存的信用卡卡號,密碼,公司的秘密文件等隱私文件或許已經被惡意的JavaScript程序上傳到了遠方的服務器上,這對用戶來說是不可容忍的。
在得到用戶允許后我們還是可以播放本地文件的,下面介紹一種方法。
在頁面中插入一個input節點并指定type為file,如果需要播放多個文件,可以添加屬性multiple。注冊文件節點被更新時的回調函數,在回調函數中調用URL.createObjectURL函數來獲取剛選擇文件的url,然后把該url設置為audio或video的src值即可。
代碼實例如下:
<html>
<body>
<input type="file" id="file" onchange="onInputFileChange()">
<audio id="audio_id" controls autoplay loop>Your browser can't support HTML5 Audio</audio>
<script>
function onInputFileChange() {
var file = document.getElementById('file').files[0];
var url = URL.createObjectURL(file);
console.log(url);
document.getElementById("audio_id").src = url;
}
</script>
</body>
</html>
該代碼在Chrome 30和Firefox 24上測試通過,在IE上應該存在一定的兼容性問題(據我所知IE8及以前的版本肯定是不能工作的),因為IE對HTML5的支持不好,不知道IE10有沒有實現相關的API。
到此,相信大家對“HTML5 Video/Audio播放本地文件的方法”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。