旧版IE(6–8)不识别HTML5语义标签,需用HTML5 Shiv通过JS创建元素并配合CSS设display:block;MediaElement.js则为video/audio提供Flash等回退播放能力;系统级解码器缺失或Content-Type错误也常导致HTML5播放失败。

旧版浏览器(尤其是 IE6–8)根本不认识 、、 这类 HTML5 标签,直接当普通未知标签处理,不渲染样式、不参与布局。这不是“插件没装好”,而是浏览器内核压根没实现这些语义元素——所以所谓“安装插件”,本质是用 JavaScript 补丁让老浏览器“假装认识”它们。
HTML5 Shiv:专治 IE8 及以下无法识别新标签
这是最轻量、最经典的兼容方案,只解决“标签不可用”问题,不涉及 或 功能补全。
- 下载
html5shiv.min.js(推荐从 GitHub 官方仓库 获取最新版) - 用条件注释精准加载,避免现代浏览器执行冗余脚本:
- 必须配合 CSS 声明,否则即使 JS 创建了元素,IE 仍默认为
inline:article, aside, dialog, footer, header, section, nav, figure, menu { display: block; }
MediaElement.js:给老浏览器塞进 HTML5 播放能力
如果你的页面有 或 标签,而用户还在用 IE8、Firefox 3.6 或旧版 Safari,光靠 Shiv 不行——它不提供播放逻辑。MediaElement.js 是真正能 fallback 到 Flash/QuickTime 的播放器封装库。
- 引入 JS 和 CSS:
- 初始化时指定
features控制回退策略(比如禁用 Flash):new MediaElementPlayer('my-video', { features: ['playpause', 'current', 'progress', 'duration', 'volume'], pluginPath: 'path/to/shims/', // Flash/SL 资源路径 shimScriptAccess: 'always' }); - 注意:Flash 已淘汰,若需支持极老环境,得自己托管
flashmediaelement.swf并确保服务器允许 MIME 类型application/x-shockwave-flash
CentOS/Firefox/Chrome 环境下 HTML5 播放失败?不是前端问题
Linux 桌面环境里,“网页显示‘不支持 HTML5 播放器’”大概率不是代码或 JS 插件的问题,而是系统级解码器缺失或 GStreamer 插件链断裂。
立即学习“前端免费学习笔记(深入)”;
- CentOS 7 必装:
sudo yum install gstreamer1-plugins-{base,good,bad-free,ugly} gstreamer1-libav ffmpeg - Firefox 需确认
about:config中media.gstreamer.enabled为true,且media.ffvpx.enabled未被手动关闭 - Chrome 用户若看到“Your browser does not support the video tag”,先检查是否启用了
--disable-gpu启动参数(某些旧显卡驱动下会意外禁用媒体栈)
别把 Polyfill 当万能膏药
HTML5 Shiv 和 MediaElement.js 都是 Polyfill,但它们只覆盖特定子集。比如:
- Shiv 不修复
localStorage、querySelector、classList——这些要用es5-shim、dom4等单独补 - MediaElement.js 不模拟
WebRTC、WebGL、Service Worker——这些根本没法靠 JS 模拟,只能降级或提示升级 - 所有 Polyfill 都增加首屏 JS 加载量和解析时间,IE8 下执行大量
document.createElement()可能导致页面卡顿
真正容易被忽略的是:很多所谓“兼容问题”,其实是后端返回了错误的 Content-Type(比如把 .js 文件发成 text/plain),导致 IE 直接拒绝执行——这种错误在开发者工具控制台里连报错都不会有,只会静默失败。











