创新互联百度小程序教程:video视频

  • video 视频
    • 属性说明
      • objectFit 有效值
      • direction 有效值
      • 主流格式支持
      • 主流编码格式支持
    • 示例
      • 代码示例 1
      • 图片示例
      • 代码示例 2:controls
      • 图片示例
      • 代码示例 3:title
      • 图片示例
      • 代码示例 4:direction
      • 图片示例
      • 代码示例 5:show-progress
      • 图片示例
      • 代码示例 6:show-no-wifi-tip
    • Bug & Tip
    • Web 态 Tip
      • Tip1:在部分浏览器下,视频无法自动播放的解决方案
      • Tip2:视频类资源地址必须有文件扩展名(即文件后缀)
      • Tip3:在部分浏览器下,视频播放器会遮挡其他页面元素 / 小窗播放问题的解决方案
      • Tip4:在部分浏览器下,视频播放器退出全屏后会暂停播放

    video 视频

    v3.70.0 起支持同层渲染,更多请参考原生组件。

    解释:视频。video 组件默认宽度 300px 、高度 225px 。该组件还提供丰富的 API 来控制视频的播放、暂停、全屏、弹幕等,详见 swan.createVideoContext 。

    属性说明

    属性名 类型 默认值 必填 说明 最低支持版本 Web 态说明

    src

    String

    视频的资源地址,支持云文件 ID

    3.120.2
    低版本请做兼容性处理

    不支持设置云文件 ID

    title

    String

    视频标题,全屏时在视频顶部展示

    3.120.2
    低版本请做兼容性处理

    暂不支持,video 全屏模式无标题

    initial-time

    Number

    指定视频初始播放位置

    --

    controls

    Boolean

    true

    是否显示默认播放控件(播放/暂停按钮、播放进度、时间)

    --

    autoplay

    Boolean

    false

    是否自动播放

    -

    存在浏览器兼容问题,详见下方 Web 态 Tip1

    loop

    Boolean

    false

    是否循环播放

    --

    muted

    Boolean

    false

    是否静音播放

    --

    objectFit

    String

    contain

    当视频大小与 video 容器大小不一致时,视频的表现形式。contain:包含;fill:填充;cover:覆盖

    --

    poster

    String

    视频封面的图片网络资源地址,支持云文件 ID

    3.120.2
    低版本请做兼容性处理

    -

    page-gesture

    Boolean

    false

    在非全屏模式下,是否开启使用手势调节亮度与音量,兼容 vslide-gesture 属性

    -

    此属性对 Web 态不生效

    direction

    Number

    按设置的视频全屏方向进入全屏。不指定视频全屏方向时则根据设备方向判断全屏方向。0:正常竖向;90:屏幕顺时针 90 度;-90:屏幕逆时针 90 度

    3.90.29
    低版本请做兼容性处理

    暂不支持

    show-progress

    Boolean

    true

    若不设置,宽度大于 240 时才会显示

    --

    show-fullscreen-btn

    Boolean

    true

    是否显示全屏按钮

    --

    enable-progress-gesture

    Boolean

    true

    是否开启使用手势控制进度

    -

    此属性对 Web 态不生效

    danmu-list

    Array.

    弹幕列表

    --

    danmu-btn

    Boolean

    false

    是否显示弹幕按钮,只在初始化时有效,不能动态变更

    -

    此属性对 Web 态不生效

    enable-danmu

    Boolean

    false

    是否展示弹幕,只在初始化时有效,不能动态变更

    --

    show-play-btn

    Boolean

    true

    是否显示视频底部控制栏的播放按钮

    --

    show-center-play-btn

    Boolean

    true

    是否显示视频中间的播放按钮

    -

    Web 态下,中间播放按钮暂不支持隐藏,设置为 false 不生效

    show-mute-btn

    Boolean

    false

    是否显示静音按钮

    3.120.2
    低版本请做兼容性处理

    Web 态下,静音按钮暂不支持隐藏,设置为 false 不生效

    show-no-wifi-tip

    Boolean

    true

    非 wifi 环境下是否显示继续播放浮层

    3.100.4
    低版本请做兼容性处理

    此属性对 Web 态不生效

    vslide-gesture

    Boolean

    false

    非全屏模式下,是否开启亮度与音量调节手势,兼容 page-gesture 属性

    3.120.2
    低版本请做兼容性处理

    此属性对 Web 态不生效

    vslide-gesture-in-fullscreen

    Boolean

    true

    全屏模式下,是否开启亮度与音量调节手势

    3.120.2
    低版本请做兼容性处理

    此属性对 Web 态不生效

    enable-play-gesture

    Boolean

    false

    是否开启播放手势,即双击切换播放/暂停

    3.120.2
    低版本请做兼容性处理

    此属性对 Web 态不生效

    show-rate-btn

    Boolean

    false

    是否显示倍速播放按钮

    3.170.2
    低版本请做兼容性处理

    -

    show-vslide-btn-in-fullscreen

    Boolean

    true

    全屏模式下,是否显示侧边栏控制按钮

    3.170.2
    低版本请做兼容性处理

    此属性对 Web 态不生效

    silent-play

    Boolean

    false

    是否进入无声视频模式,进入无声视频模式后,视频将静音播放且不响应系统物理音量变化,点击播放器提示无声视频,手势调节失效

    3.170.2
    低版本请做兼容性处理

    此属性对 Web 态不生效

    bindplay

    EventHandle

    当开始播放时触发 play 事件

    --

    bindpause

    EventHandle

    当暂停播放时触发 pause 事件

    --

    bindended

    EventHandle

    当播放到末尾时触发 ended 事件

    --

    bindtimeupdate

    EventHandle

    播放进度变化时触发。event.detail = {currentTime, duration}

    --

    bindfullscreenchange

    EventHandle

    当视频进入和退出全屏时触发。event.detail = {fullscreen, direction},direction 取为 vertical 或 horizontal

    --

    bindwaiting

    EventHandle

    视频出现缓冲时触发

    --

    binderror

    EventHandle

    视频播放出错时触发

    -

    Web 态目前触发 error 后直接展示默认错误信息,不执行开发者的 error 回调函数

    bindloadedmetadata

    EventHandle

    视频元数据加载完成时触发。event.detail = {width, height, duration}

    3.180.1
    低版本请做兼容性处理

    -

    objectFit 有效值

    说明
    contain包含
    fill填充
    cover覆盖

    direction 有效值

    说明
    0正常竖向
    90屏幕顺时针 90 度
    -90屏幕逆时针 90 度

    主流格式支持

    格式 Android iOS Web 态
    mp4
    mov
    m4v
    3gp
    avi
    m3u8
    webm
    flv
    mkv
    rmvb
    rm
    ogg

    主流编码格式支持

    格式 Android iOS

    H.263

    H.264

    HEVC

    MPEG-4

    VP8

    VP9

    示例

    跳转编辑工具

    在开发者工具中打开

    在 WEB IDE 中打开

    扫码体验

    代码示例

    请使用百度APP扫码

    代码示例 1

    • SWAN
    • JS
     
     
     
    1. style="width: 100%;"
    2. id="myVideo"
    3. title="这是title"
    4. src="{{src}}"
    5. initial-time="{{initialTime}}"
    6. duration="48"
    7. controls="{{controls}}"
    8. autoplay="{{false}}"
    9. loop="{{false}}"
    10. muted="{{voice}}"
    11. objectFit="{{objectFit}}"
    12. poster="{{posterSrc}}"
    13. page-gesture="{{pageGesture}}"
    14. direction="{{0}}"
    15. show-progress="{{progressGesture}}"
    16. show-fullscreen-btn="{{fullscreenBtn}}"
    17. enable-progress-gesture="{{false}}"
    18. danmu-list="{{danmuList}}"
    19. danmu-btn="{{true}}"
    20. enable-danmu="{{true}}"
    21. show-play-btn="{{playBtn}}"
    22. show-center-play-btn="{{centerPlayBtn}}"
    23. show-mute-btn="{{true}}"
    24. show-no-wifi-tip="{{noWifiTip}}"
    25. show-rate-btn="{{showRateBtn}}"
    26. show-vslide-btn-in-fullscreen="{{showVslideBtnInFullscreen}}"
    27. silent-play="{{silentPlay}}"
    28. vslide-gesture="{{true}}"
    29. vslide-gesture-in-fullscreen="{{true}}"
    30. enable-play-gesture="{{true}}"
    31. bindplay="videoPlay"
    32. bindpause="videoPause"
    33. binderror="videoError"
    34. bindended="videoEnded"
    35. bindwaiting="videoWaiting"
    36. bindtimeupdate="videoTimeupdate"
    37. bindfullscreenchange="fullscreen"
    38. bindloadedmetadata="loadedmetadata">
    39. 弹幕内容
    40. 指定初始播放位置为20s(播放前点击)
    41. 显示默认播放控件
    42. 设置循环播放
    43. 点击{{voice ? '有音':'无音'}}
    44. 包含容器
    45. 填充容器
    46. 覆盖容器
    47. 开启手势调节亮度与音量
    48. {{fullscreenBtn?'不显示':'显示'}}全屏按钮
    49. 去掉全屏播放时手势控制进度
    50. {{playBtn ? '': '不'}}显示视频底部控制栏的播放按钮
    51. {{centerPlayBtn ? '': '不'}}显示视频中间的播放按钮
    52. wifi/4g浮层
    53. 切换视频地址
    54. {{showRateBtn ? '隐藏' : '显示'}}倍速播放按钮
    55. {{showVslideBtnInFullscreen ? '隐藏': '显示'}}全屏模式下的侧边栏控件
    56. {{silentPlay ? '关闭': '开启'}}无声视频模式

    设计指南

    默认情况,会在 video 组件的中间和左下角显示 2 个 play-btn,请根据小程序自身需要合理配置。不建议同时使用 2 个 play-btn,过多元素会增加用户理解成本。

    正确

    只用一个 play-btn,指引明确

    错误

    同时使用2个 play-btn,增加用户理解成本

    图片示例

    代码示例 2:controls

    在开发者工具中打开

    在开发者工具中打开

    在 WEB IDE 中打开

    • SWAN
    • JS
     
     
     
    1. style="width: 100%;"
    2. id="myVideo"
    3. src="{{src}}"
    4. controls="{{controls}}">

    图片示例

    代码示例 3:title

    在开发者工具中打开

    在开发者工具中打开

    在 WEB IDE 中打开

    • SWAN
     
     
     
    1. style="width: 100%;"
    2. id="myVideo"
    3. src="https://b.bdstatic.com/swan-temp/940fe716b0eaad38f47b209d61657490.mp4"
    4. title="全屏title">

    图片示例

    代码示例 4:direction

    在开发者工具中打开

    在开发者工具中打开

    在 WEB IDE 中打开

    • SWAN
    • JS
     
     
     
    1. style="width: 100%;"
    2. id="myVideo"
    3. src="{{src}}"
    4. direction="{{direction}}">

    图片示例

    代码示例 5:show-progress

    在开发者工具中打开

    在开发者工具中打开

    在 WEB IDE 中打开

    • SWAN
     
     
     
    1. style="width: 100%;"
    2. id="myVideo"
    3. src="https://b.bdstatic.com/swan-temp/940fe716b0eaad38f47b209d61657490.mp4"
    4. show-progress="{{true}}">

    图片示例

    代码示例 6:show-no-wifi-tip

    在开发者工具中打开

    在开发者工具中打开

    在 WEB IDE 中打开

    • SWAN
     
     
     
    1. style="width: 100%;"
    2. id="myVideo"
    3. src="{{src}}"
    4. show-no-wifi-tip="{{true}}">

    Bug & Tip

    • Bug:百度 App 11.26 版本,在视频列表场景下,同时设置show-play-btn属性和show-center-play-btn属性值为true可能会出现失焦视频播放控件不显示的情况,因此建议在视频列表场景中,将video组件的show-play-btn属性设置为false
    • Tip:同一页面下的 video 标签不应太多,建议不超过 5 个,视频列表功能建议使用 image 列表,选中时替换为 video 。
    • Tip:避免多个 video 同时播放,视频预览建议使用 gif 方案,使用 video 会降低性能和体验。

    Web 态 Tip

    Tip1:在部分浏览器下,视频无法自动播放的解决方案

    案例分析
    出于用户体验、节省流量等原因,OS 的 Safari、版本号 66 及以上的 Chrome、以及大部分国产移动浏览器禁止视频在非静音状态下自动播放。因此,Web 态针对 video 组件中 autoplay 属性设置为 true 后做了如下处理:

    • 对于 QQ、Android 微信、 QQ 浏览器等基于 X5 内核的平台,Web 态下设置的 autoplay = true 不生效,页面进入时,视频组件上显示播放按钮供用户主动点击触发播放。
    • 对于其他非 X5 内核的平台,为保证页面进入时可自动播放,会默认关闭声音播放,并显示“取消静音”按钮,供用户主动开启声音。
    • 为“取消静音”和播放按钮设置了较高的 z-index 样式层级,开发者可以根据需要来决定是否覆盖这两类按钮。

    由于浏览器种类众多,如出现自动播放相关新问题,请将案例反馈给我们,我们将统一记录并反馈进展。

    Tip2:视频类资源地址必须有文件扩展名(即文件后缀)

    由于浏览器无法解析资源格式。因此对于视频类资源,应在地址中通过后缀名显式声明资源格式,否则可能会导致视频无法正常播放:

    • Web 态 video 组件目前支持 mp4、mov、m4v、ogg、m3u8 等格式,参见上述主流格式支持小节。
    • 当 video 组件的 src 属性值没有文件扩展名,视频会被按照 mp4 格式来进行解码播放

    Tip3:在部分浏览器下,视频播放器会遮挡其他页面元素 / 小窗播放问题的解决方案

    案例分析
    微信、百度 App、UC 等浏览器实现了自身的播放器控件,劫持了默认内核提供的播放器样式和逻辑,从而使得基于 H5 video 实现的 Web 态 video 组件出现了以下问题:

    • 在 Android 系统的微信平台、百度 App 和 UC 等国产移动浏览器下,Video 组件的播放器会覆盖到页面其他内容之上,且无法通过 z-index 控制层级,从而导致一些交互失效(比如无法上下滑动触发切换视频)。
    • 在 OPPO 手机下的百度 App,会出现小窗播放。

    解决方案
    Web 态针对不同浏览器做了尽可能的修复,以解决此问题。已修复的包括 QQ、Android 微信、QQ 浏览器等基于 X5 内核的平台,百度 App。但由于浏览器种类众多,有可能存在我们暂未覆盖到的情况。如仍遇到上述问题,请您将案例反馈给我们,我们将统一记录并反馈进展。

    Tip4:在部分浏览器下,视频播放器退出全屏后会暂停播放

    案例分析
    微信、QQ、QQ 浏览器等实现了自身的播放控件,从而使得 video 组件在退出全屏时出现视频暂停播放的问题。

    解决方案
    Web 态针对 Android 下的微信、QQ 等基于 X5 内核的平台在退出全屏时展示一个中间播放按钮,供用户点击来继续播放视频。OS 下因无法监听退出全屏事件,此问题暂无法解决。

    当前文章:创新互联百度小程序教程:video视频
    标题路径:http://www.mswzjz.cn/qtweb/news4/462254.html

    攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

    广告

    声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能