视频播放器

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;

相关推荐
!win !3 小时前
前端跨标签页通信方案(下)
前端·javascript
用户47949283569154 小时前
TypeScript 简史:它是怎么拯救我的烂代码的
javascript·typescript
用户47949283569154 小时前
只有前端 Leader 才会告诉你:那些年踩过的模块加载失败的坑(二)
javascript
xw55 小时前
前端跨标签页通信方案(下)
前端·javascript
加洛斯5 小时前
前端小知识003:JS中 == 与 === 的区别
开发语言·前端·javascript
G***E3165 小时前
前端路由懒加载实现,Vue Router与React Router
前端·vue.js·react.js
stereohomology6 小时前
ffmpeg视频mp4到gif用大模型很方便
ffmpeg·音视频
半桶水专家6 小时前
ES Module 原理详解
前端·javascript
冴羽6 小时前
Cloudflare 崩溃梗图
前端·javascript·vue.js
Jonathan Star7 小时前
JavaScript 中,原型链的**最顶端(终极原型)只有一个——`Object.prototype`
开发语言·javascript·原型模式