gpt4 book ai didi

javascript - HTML5 视频自定义控件

转载 作者:行者123 更新时间:2023-11-27 22:57:20 26 4
gpt4 key购买 nike

我正在尝试向我的 html 5 视频添加一些自定义控件,但在使其正常工作时遇到问题。

我需要添加一个切换按钮“暂停”和“播放”。这是我的代码的一部分我收到的错误是 Uncaught TypeError: Cannot set property 'title' of null

var billboardC, video, playpause;
var videoBGPlayer;

function init(){

billboardC = document.getElementById('billboardC');

video = document.getElementById('video-player');
playpause = document.getElementById('playpause');
}


function OpenVideo(e){
console.log('open video');
billboardC.innerHTML += "<div class='closeButton'></div>";
billboardC.innerHTML += "<a href='www.google.com' target='blank' class='fombutton'>Find Out More</a>";
billboardC.style.visibility = 'visible';
billboardC.innerHTML += "<video id='video-player' class='videoSquare' poster='' muted> <source src='my-video.mp4' type='video/mp4' /></video><div id='controls'><button id='playpause' onclick='togglePlayPause()' title='play'>Play</button></div>";

}

function togglePlayPause() {
if (video.paused || video.ended) {
playpause.title = "pause";
playpause.innerHTML = "pause";
video.play();
console.log('play');
}
else {
playpause.title = "play";
playpause.innerHTML = "play";
video.pause();
console.log('pause');
}
}


window.onload = function(){ init(); }

谢谢

最佳答案

详细描述位于代码段内的评论中。

片段

    var billboardC = document.getElementById('billboardC');
var videoBGPlayer;

/*
The variables that were within init() were not accessible by other functions.

Normally you would just place the variables outside to become global and accessible. But all of the elements do not exist until OpenVideo() is finished parsing them, so the variables are undefined.

In order to create useful references, I placed the needed variables within togglePlayPause().

*/
/*
OpenVideo() was never invoked, therefore no HTML, no dice. So I placed OpenVideo within init() so it would be the first function (besides init() of course to be invoked.
*/
function init(){
OpenVideo();
}

function OpenVideo(){
console.log('open video');
billboardC.innerHTML += "<div class='closeButton'></div>";
billboardC.innerHTML += "<a href='www.google.com' target='_blank' class='formbutton'>Find Out More</a>";
billboardC.style.visibility = 'visible';
billboardC.innerHTML += "<video id='video-player' class='videoSquare' poster='' muted> <source src='my-video.mp4' type='video/mp4'></video><div id='controls'><button id='playpause' onclick='togglePlayPause()' title='play'>Play</button></div>";

}

function togglePlayPause() {
var video = document.getElementById('video-player');
var playpause = document.getElementById('playpause');
if (video.paused || video.ended) {
playpause.title = "pause";
playpause.innerHTML = "pause";
video.play();
console.log('play');
}
else {
playpause.title = "play";
playpause.innerHTML = "play";
video.pause();
console.log('pause');
}
}

/*
When using window.onload = foo; do not use the functions parenthesis `()`. If you leave out the paranthesis, that will tell the renderer that it is up to it to decide when init should execute.
*/
window.onload = init;
<!--#billboardC didn't exsist and it wasn't included in OpenVideo()-->
<main id="billboardC"></main>

关于javascript - HTML5 视频自定义控件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37474083/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com