最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 【前端性能优化指南】5.5 - 优化你的视频资源

    正文概述 掘金(AlienZHOU)   2021-06-05   1062

    视频

    ? 页面静态资源 | ? 上一站 - 字体

    视频作为一种重要的媒体形态,在网站中使用可以提高网站内容的丰富性,但同时对网络加载来说也是一个负担。所以会出现一些如下针对 Web 上视频的优化。

    1. 使用合适的视频格式

    与图片类似,不同的视频编码格式,其数据大小也大都不同。目前在 HTML5 Video 中常用的格式为 MPEG-4。除了 MPEG-4 之外,还支持一种叫 WebM 的新的视频格式。

    WebM(VP9) 相较于 MPEG-4(x264) 来说会更小,不过兼容性(2021.6.5)相对来说也较差。因此可以考虑在 <video> 中指定多个 <source>

    <video>
        <source src="/static/video/me.webm" type="video/webm">
        <source src="/static/video/me.mp4" type="video/mp4">
    </video>
    

    此外,使用 AV1 编码[1]会比 VP9(WebM) 小约30%,比 x264(MPEG-4) 小约45-50%[2]

    2. 视频压缩

    对于视频,我们也可以进行有损与无损压缩,同样可以有效减少视频大小。下面列举了一些常用的工具:

    • HandBrake
    • Freemake
    • Hybrid
    • MeGUI

    3. 移除不必要的音轨信息

    在上一节中我们提到,可以使用 <video> 代替 GIF 来实现动画,同时体积也会更小。由于在这种场景下本身就是不需要声音的,所以我们会将 <video> 设置为 muted

    那么,既然不需要声音,我们是不是可以直接移除掉音轨的数据?是的,这样做也会帮助进一步缩减视频的体积。

    4. 使用“流”

    尝试让浏览器使用“流”或者小分片的方式来播放你的视频,例如常用的 HLS (HTTP Live Streaming) 技术。简单来说,使用 HLS 技术,你的视频会包含一个 .m3u8 的索引文件和一系列包含播放内容的 .ts 分片。浏览器通过不断下载一小段的分片来进行视频播放,避免了完整视频下载的流量消耗。

    你也可以尝试使用 MPEG-DASH[3] 这个技术,目前开源社区也有一个配套的客户端实现。

    5. 移除不必要的视频

    对于不需要使用视频的场景,最好的优化方法就是去掉视频。例如在小屏幕上,你可以通过媒体查询来避免下载视频:

    @media screen and (max-width: 650px) {
        #hero-video {
            display: none;
        }
    }
    

    关于视频的优化这里只介绍了一些基本的手段,但对于一个重度的视频网站来说,会包含例如播放器 SDK 的优化、数据预取、码率自适应等更多的优化内容。参考资料包含 B 站的一个关于视频体验优化的分享[4],感兴趣的同学可以进一步阅读下。

    此外,虽然上面介绍了一些视频处理的软件工具,但是如果有更高的定制化或集成需求,建议使用 FFmpeg[5] 或相关的库来处理。


    「性能优化」系列内容

    1. 带你全面掌握前端性能优化 ?
    2. 如何利用缓存减少远程请求?
    3. 如何加快请求速度?
    4. 如何加速页面解析与处理?
    5. 静态资源优化的总体思路是什么?
      1. 如何针对 JavaScript 进行性能优化?
      2. 如何针对 CSS 进行性能优化?
      3. 图片虽好,但也会带来性能问题
      4. 字体也需要性能优化么?
      5. 如何针对视频进行性能优化?(本文)
    6. ? 如何避免运行时的性能问题?
    7. 如何通过预加载来提升性能?
    8. 尾声

    参考资料

    1. a technial overview of the AV1
    2. Speed Essentials: Key Techniques for Fast Websites (Chrome Dev Summit 2018)
    3. Dynamic Adaptive Streaming over HTTP (Wikipedia)
    4. 2019 GMTC 分享 - B 站的视频体验进化之路
    5. FFmepg
    6. 8 Video Optimization Tips for Faster Loading Times
    7. Optimizing MP4 Video for Fast Streaming
    8. Web Performance 101: Video Optimization

    起源地下载网 » 【前端性能优化指南】5.5 - 优化你的视频资源

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元