- 流式播放: Griffith 让流式播放变得简单。无论你的视频格式是 mp4 还是 hls,Griffith 都能使用媒体源拓展(MSE)来实现分段加载等功能。
- 可扩展性: Griffith 让 React 应用接入视频播放功能变得简单。如果你的应用不基于 React,Griffith 还提供支持 standalone 模式可以免构建工具直接在浏览器中使用。
- 可靠性: Griffith 已经大范围应用知乎的桌面和移动 web 应用中。
yarn add griffith
import Player from 'griffith'
const sources = {
hd: {
play_url: 'https://zhstatic.zhihu.com/cfe/griffith/zhihu2018_hd.mp4',
},
sd: {
play_url: 'https://zhstatic.zhihu.com/cfe/griffith/zhihu2018_sd.mp4',
},
}
render(<Player sources={sources} />)
注意:暂不支持 SSR 应用
<script src="https://unpkg.com/griffith-standalone/dist/index.umd.min.js"></script>
const sources = {
hd: {
play_url: 'https://zhstatic.zhihu.com/cfe/griffith/zhihu2018_hd.mp4',
},
sd: {
play_url: 'https://zhstatic.zhihu.com/cfe/griffith/zhihu2018_sd.mp4',
},
}
Griffith.createPlayer(element).render({sources})
Griffith 是一个 Monorepo,使用了 Yarn workspace 和 Lerna 进行管理。
packages/griffith
: 核心代码
packages/griffith-message
: 帮助进行跨窗口通信packages/griffith-utils
: 公用的工具函数
packages/griffith-mp4
: MP4 插件。使用了 MediaSource APIpackages/griffith-hls
: HLS 插件,使用了 hls.js
example
: 示例packages/griffith-standalone
: 包含了所有依赖的 UMD 包,可以免除构建工具,独立在浏览器中使用。
默认情况下,webpack 等构建工具会将 griffith-mp4
和 packages/griffith-hls
打包。你可以通过构建时注入全局变量来除去插件,从而减小打包大小。
如果你使用 webpack,可以使用 DefinePlugin:
const {DefinePlugin} = require('webpack')
module.exports = {
plugins: [
new DefinePlugin({
__WITHOUT_HLSJS__: JSON.stringify(true), // 除去 griffith-hls
__WITHOUT_MP4__: JSON.stringify(true), // 除去 griffith-mp4
}),
],
}
注意,除去 griffith-mp4
/ griffith-hls
之后,除非浏览器原生支持,否则 Griffith 不能播放 MP4 / HLS 视频。
阅读以下内容,了解如何参与改进 Griffith。
查看我们的贡献指南来了解我们的开发流程。
MIT