首页前端开发其他前端知识HTML5浏览器和audio音频格式兼容性问题怎么解决

HTML5浏览器和audio音频格式兼容性问题怎么解决

时间2024-03-27 06:40:03发布访客分类其他前端知识浏览531
导读:这篇文章主要为大家详细介绍了HTML5浏览器和audio音频格式兼容性问题怎么解决,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望对大家学习或工作能有帮助。 HTML5 Audio标签能...
这篇文章主要为大家详细介绍了HTML5浏览器和audio音频格式兼容性问题怎么解决,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望对大家学习或工作能有帮助。



HTML5 Audio标签能够支持wav, mp3, ogg, acc, webm等格式,但有个很重要的音乐文件格式midi(扩展名mid)却在各大浏览器中都没有内置的支持。不是所有的浏览器都支持MP3 OGG之类的,每个浏览器因为版权的问题支持的格式都是不一样的。这篇文章给大家介绍html5中audio支持音频格式的解决方法,感兴趣的朋友一起看看吧。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。

浏览器和音频兼容性

浏览器制造商并非都同意使用某种音频文件格式。对于图像,PNG、JPEG 或 GIF 格式的文件在任何浏览器上都能加载到您的网页里。遗憾的是,音频文件并非如此。表 1 展示了网页中可以使用的音频文件格式,但是并非所有格式都能用于所有浏览器。例如,Chrome、Internet Explorer 9 (IE9) 和 Safari 浏览器不支持 WAV 文件,这是一种使用非压缩格式且正在衰败的标准。

HTML5浏览器和音频格式兼容性

音频格式 Chrome Firefox IE9 Opera Safari
OGG 支持 支持 支持 不支持 不支持
MP3 支持 不支持 支持 不支持 支持
WAV 不支持 支持 不支持 支持 不支持

没有一种通用的文件格式让每个浏览器都使用单个文件格式意味着至少有 2/5 的浏览器无法播放某些声音。这不是无法在单一音频标准中达成一致的浏览器制造商不妥协的问题,而是涉及专利权和特许权使用费的法律和财务问题。不受软件专利限制的 OGG 格式旨在一劳永逸地解决这个问题。然而,在撰写本文时,Opera 和 Safari 都不支持 OGG。与 OGG 格式的文件相比,可用的 WAV 和 MP3 文件数量要更多,因此毫无疑问,浏览器制造商考虑到了这一点。MP3 作为事实的标准是个很好的解决方案。

解决方案:使用三种文件类型和audio> 标签

鉴于目前的状况,您可能认为目前还不是在 HTML5 页面上使用音频的黄金时刻。在某些方面可能的确如此,但是 HTML5 提供了一个解决方案,使您喜欢的浏览器能够找到一种兼容的格式。

与 audio> 标签结合使用时,source> 标签可以嵌套在 audio> 容器内。假设您是一个瓦格纳迷,想在 HTML5 网页上听他的歌剧 Ride of the Valkyries(《女武神》)。首先,您需要获得三种文件类型的音乐,即 OGG、MP3 和 WAV。将这些音乐文件与 HTML5 文件放在同一个文件夹内。然后,将每个文件名放在单独的 source> 标签里,并且音频容器中的所有源标签都由audio> /audio> 构成,如下所示。

audio controls>
    
    source src=”http://demo.mimvp.com/html5/take_you_fly.ogg” />
    
    source src=”http://demo.mimvp.com/html5/take_you_fly.mp3″ />
    
    source src=”http://demo.mimvp.com/html5/take_you_fly.wav” />
    
/audio>
    

无论访问者使用什么浏览器,它都将自动选择所读取的第一个文件类型,并为您播放声音。


通过以上内容的阐述,相信大家对“HTML5浏览器和audio音频格式兼容性问题怎么解决”已经有了进一步的了解,更多相关的问题,欢迎关注网络或到官网咨询客服。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: HTML5浏览器和audio音频格式兼容性问题怎么解决
本文地址: https://pptw.com/jishu/654045.html
HTML5中postMessage跨域通信的解决方案是什么 golang是如何生成JSON和解析JSON的,方法是什么?

游客 回复需填写必要信息