vue移动端项目经验(二)

视频插件vue-video-player的使用及注意事项

官方文档
video.js:https://docs.videojs.com/docs/api/player.html
vue-video-player:https://github.com/surmon-china/vue-video-player

1、包的安装
npm install vue-video-player --save

2、包的引入
import VideoPlayer from 'vue-video-player'
require('video.js/dist/video-js.css')  //若此行报错无法找到,则改为require('vue-video-player/node_modules/video.js/dist/video-js.css')
require('vue-video-player/src/custom-theme.css')
Vue.use(VideoPlayer)

3、插件使用
html部分
<div style="overflow:hidden">  //移动端当屏幕宽度较小时,此视频控件调节音量时会使得屏幕出现横向滚动条,故在父级盒子使用overflow:hidden来阻止滚动条出现,以免影响用户体验。
    <video-player  class="video-player vjs-custom-skin"
        ref="videoPlayer" 
        :playsinline="true" 
        :options="playerOptions"   //相关配置
        @play="onPlayerPlay($event)"//监听开始状态(非必需),这是事件,按需使用
        @pause="onPlayerPause($event)"//监听暂停状态(非必需),这是事件,按需使用
    >
    </video-player>
</div>


js部分
data(){
    return{

        playerOptions : {
            playbackRates: [0.5, 1.0, 1.5, 2.0], //播放速度
            autoplay: false, //如果true,浏览器准备好时开始回放。
            muted: false, // 默认情况下将会消除任何音频。
            loop: false, // 导致视频一结束就重新开始。
            preload: 'auto', // 建议浏览器在<video>加载元素后是否应该开始下载视频数据。auto浏览器选择最佳行为,立即开始加载视频(如果浏览器支持)
            language: 'zh-CN',
            aspectRatio: '16:9', // 将播放器置于流畅模式,并在计算播放器的动态大小时使用该值。值应该代表一个比例 - 用冒号分隔的两个数字(例如"16:9"或"4:3")
            fluid: true, // 当true时,Video.js player将拥有流体大小。换句话说,它将按比例缩放以适应其容器。
            sources: [{
                type: "",//这里的种类支持很多种:基本视频格式、直播、流媒体等,具体可以参看git网址项目
                src: "" //url地址
            }],
            poster: "../../static/images/test.jpg", //你的封面地址
            // width: document.documentElement.clientWidth, //播放器宽度
            notSupportedMessage: '此视频暂无法播放,请稍后再试', //允许覆盖Video.js无法播放媒体源时显示的默认信息。
            controlBar: {
                  timeDivider: true,  //当前时间和持续时间的分隔符
                  durationDisplay: true,  //显示持续时间
                  remainingTimeDisplay: false,  //是否显示剩余时间功能
                  fullscreenToggle: true  //全屏按钮
            }
        }

    }
},

//挂载视频组件(非必须)不写这一步也可以实现播放,添加这个是为了自定义按钮使用
computed: {
    player() {
        return this.$refs.videoPlayer.player//自定义播放
    }
},

vue移动端项目经验(二)

上一篇:建立一个无限移动的蛇形边框动画


下一篇:Android自动化测试------monkey(三)