| 1 |
- import{c as t,o as e,C as o}from"./vendor.ed841bd5.js";const n={class:"markdown-body"},d=o('<h1>video 视频播放器</h1><h3>介绍</h3><p>原生video实现的视频播放器</p><h3>安装</h3><pre><code class="language-javascript">import { createApp } from 'vue';\nimport { Video } from '@nutui/nutui';\n\nconst app = createApp();\napp.use(Video);\n</code></pre><h2>代码演示</h2><h3>基础用法</h3><pre><code class="language-html"><nut-video\n :source="source"\n @play="play"\n @pause="pause"\n @playend="playend">\n</nut-video>\n</code></pre><pre><code class="language-javascript">setup() {\n const state = reactive({\n source: {\n src: 'https://storage.jd.com/about/big-final.mp4',\n type: 'video/mp4'\n }\n });\n const play = (elm: any) => console.log('play', elm);\n const pause = (elm: any) => console.log('pause', elm);\n const playend = (elm: any) => console.log('playend', elm);\n\n return { play, pause, playend, ...toRefs(state) };\n}\n</code></pre><h3>自动播放</h3><p>autoplay 属性设置视频自动播放</p><pre><code class="language-html"><nut-video :source="source" :options="options"></nut-video>\n</code></pre><pre><code class="language-javascript">setup() {\n const state = reactive({\n source: {\n src: 'https://storage.jd.com/about/big-final.mp4',\n type: 'video/mp4'\n },\n options: {\n autoplay: true,\n muted: true,\n controls: true\n },\n });\n\n return { ...toRefs(state) };\n}\n</code></pre><h3>初始化静音</h3><p>muted属性设置视频初始化静音</p><pre><code class="language-html"><nut-video :source="source" :options="options"></nut-video>\n</code></pre><pre><code class="language-javascript">setup() {\n const state = reactive({\n source: {\n src: 'https://storage.jd.com/about/big-final.mp4',\n type: 'video/mp4'\n },\n options: {\n muted: true,\n controls: true\n },\n });\n\n return { ...toRefs(state) };\n}\n</code></pre><h3>视频封面海报设置</h3><p>poster 属性设置视频海报</p><pre><code class="language-html"><nut-video :source="source" :options="options"></nut-video>\n</code></pre><pre><code class="language-javascript">setup() {\n const state = reactive({\n source: {\n src: 'https://storage.jd.com/about/big-final.mp4',\n type: 'video/mp4'\n },\n options: {\n controls: true,\n poster: 'https://img12.360buyimg.com/ling/s345x208_jfs/t1/168105/33/8417/54825/603df06dEfcddc4cb/21f9f5d0a1b3dad4.jpg.webp'\n },\n });\n\n return { ...toRefs(state) };\n}\n</code></pre><h3>行内播放</h3><p>playsinline 属性设置移动端视频行内播放,阻止新打开页面播放(兼容 ios,兼容部分安卓机)</p><pre><code class="language-html"><nut-video :source="source" :options="options"></nut-video>\n</code></pre><pre><code class="language-javascript">setup() {\n const state = reactive({\n source: {\n src: 'https://storage.jd.com/about/big-final.mp4',\n type: 'video/mp4'\n },\n options: {\n playsinline: true,\n controls: true,\n },\n });\n\n return { ...toRefs(state) };\n}\n</code></pre><h3>视频背景图</h3><p>当设置视频为背景图时需要将 muted 静音、 disabled 禁止操作、loop 循环播放、autoplay 自动播放设置为 true,移动端需要设置 playsinline 行内展示</p><pre><code class="language-html"><nut-video :source="source" :options="options"></nut-video>\n</code></pre><pre><code class="language-javascript">setup() {\n const state = reactive({\n source: {\n src: 'https://storage.jd.com/about/big-final.mp4',\n type: 'video/mp4'\n },\n options: {\n controls: false,\n autoplay: true,\n muted: true,\n disabled: true,\n playsinline: true,\n loop: true\n },\n });\n\n return { ...toRefs(state) };\n}\n</code></pre><h3>视频切换</h3><p>当视频地址发生变化时,重置视频</p><pre><code class="language-html"><nut-video :source="source"></nut-video>\n<nut-button type="primary" @click="changeVideo">切换视频</nut-button>\n</code></pre><pre><code class="language-javascript">setup() {\n const state = reactive({\n source: {\n src: 'https://storage.jd.com/about/big-final.mp4',\n type: 'video/mp4'\n },\n });\n const changeVideo = () => {\n state.source1 = {\n src: 'https://vjs.zencdn.net/v/oceans.mp4',\n type: 'video/mp4'\n };\n };\n\n return { ...toRefs(state), changeVideo };\n}\n</code></pre><h2>API</h2><h3>Props</h3><table><thead><tr><th>字段</th><th>说明</th><th>类型</th><th>默认值</th></tr></thead><tbody><tr><td>source</td><td>视频地址和类型设置</td><td>Object</td><td>-</td></tr><tr><td>options</td><td>控制视频播放属性</td><td>Object</td><td>required</td></tr><tr><td>options.autoplay</td><td>是否自动播放</td><td>Boolean</td><td>false</td></tr><tr><td>options.poster</td><td>海报设置</td><td>String</td><td>-</td></tr><tr><td>options.loop</td><td>是否循环播放</td><td>Boolean</td><td>false</td></tr><tr><td>options.controls</td><td>是否展示操作栏</td><td>Boolean</td><td>true</td></tr><tr><td>options.muted</td><td>是否静音</td><td>Boolean</td><td>false</td></tr><tr><td>options.volume</td><td>音量控制</td><td>Number</td><td>0.5</td></tr><tr><td>options.disabled</td><td>禁用操作(如循环播放的背景图,禁止操作)</td><td>Boolean</td><td>false</td></tr><tr><td>options.playsinline</td><td>是否设置为行内播放元素(解决安卓兼容问题)</td><td>Boolean</td><td>false</td></tr></tbody></table><h3>Events</h3><table><thead><tr><th>事件名称</th><th>说明</th><th>回调参数</th></tr></thead><tbody><tr><td>play</td><td>播放</td><td>–</td></tr><tr><td>pause</td><td>暂停</td><td>–</td></tr><tr><td>playend</td><td>播放完成回调</td><td>–</td></tr></tbody></table>',38),s={expose:[],setup:o=>(o,s)=>(e(),t("div",n,[d]))};export default s;
|