视频播放器

import React from 'react';

class Player extends React.Component {

constructor(props) {

super(props);

}

componentDidMount() {

if(!window.polyvLivePlayer){

this.loadScript('https://player.polyv.net/resp/live-h5-player/latest/liveplayer.min.js')

.then(() =>{

this.loadPlayer();

});

}

}

componentWillUnmount() {

if(this.player){

this.player.destroy();

}

}

loadPlayer() {

this.player = window.polyvLivePlayer({

wrap: '.player',

width: '100%',

height: '100%',

uid: 'uid',

vid: 'vid',

});

}

loadScript(src) {

const headElement = document.head || document.getElementsByTagName('head')[0];

const _importedScript = {};

return new Promise((resolve, reject) => {

if (src in _importedScript) {

resolve();

return;

}

const script = document.createElement('script');

script.type = 'text/javascript';

script.onerror = err => {

headElement.removeChild(script);

reject(new URIError(`The Script ${src} is no accessible.`));

}

script.onload = () => {

_importedScript[src] = true;

resolve();

}

headElement.appendChild(script);

script.src = src;

})

}

render() {

return (

<div className="wrap">

<div className="player"></div>

</div>

)

}

}

export default Player;

相关推荐
发现一只大呆瓜26 分钟前
SSO单点登录:从同域到跨域实战
前端·javascript·面试
发现一只大呆瓜27 分钟前
告别登录中断:前端双 Token无感刷新
前端·javascript·面试
Cg136269159741 小时前
JS-对象-Dom案例
开发语言·前端·javascript
va学弟2 小时前
Java 网络通信编程(6):视频通话
java·服务器·网络·音视频
lxh01132 小时前
数据流的中位数
开发语言·前端·javascript
chy000013 小时前
视频播放器无法连接网络问题排查与解决总结
网络·音视频
zadyd4 小时前
Workflow or ReAct ?
前端·react.js·前端框架
雨雨雨雨雨别下啦6 小时前
Vue案例——面经
前端·javascript·vue.js
从文处安6 小时前
「前端何去何从」(React教程)React 状态管理:从局部 State 到可扩展架构
前端·react.js
Wect7 小时前
React Scheduler & Lane 详解
前端·react.js·面试