admin管理员组文章数量:1344181
I've got a site with an HTML5 audio player and embedded YouTube music videos. I'd like to make it so that when the user clicks on a YouTube video to play it the music will stop. Wrapping the iframe in
<div id='vidWrapper' onclick='pauseAudio()'>YT stuff</div>
works for the sliver of pixels outside of the iframe, but not when you click on the actual video. Anyone have any ideas?
I've got a site with an HTML5 audio player and embedded YouTube music videos. I'd like to make it so that when the user clicks on a YouTube video to play it the music will stop. Wrapping the iframe in
<div id='vidWrapper' onclick='pauseAudio()'>YT stuff</div>
works for the sliver of pixels outside of the iframe, but not when you click on the actual video. Anyone have any ideas?
Share Improve this question asked Apr 15, 2015 at 2:38 leitningleitning 1,5061 gold badge9 silver badges13 bronze badges3 Answers
Reset to default 8You should use the YouTube IFrame API. Add an event listener for onStateChange
to get notified when the player's state changes. See the sample code below.
<!DOCTYPE html>
<html>
<head>
<script src="https://www.youtube./iframe_api"></script>
</head>
<body>
<div id='vidWrapper'>
<!-- The <iframe> (and video player) will replace this <div> tag. -->
<div id="ytplayer"></div>
</div>
<script>
var player;
function onYouTubeIframeAPIReady() {
player = new YT.Player('ytplayer', {
height: '390',
width: '640',
videoId: 'M7lc1UVf-VE',
events: {
'onStateChange': function(event) {
if (event.data == YT.PlayerState.PLAYING) {
pauseAudio();
}
}
}
});
}
function pauseAudio() {
...
}
</script>
</body>
</html>
//More Refined Way to answer this question would be --
//HTML code----
<!DOCTYPE html>
<html>
<body>
<div id='vidWrapper'>
//your iframe tag goes here.
<iframe id="video-id-first" src="https://www.youtube./embed/nNlEiuqiKAk?enablejsapi=1&origin=http%3A%2F%2F3.7.232.244" gesture="media" allow="encrypted-media" allowfullscreen="" data-gtm-yt-inspected-53610233_3="true" width="560" height="400" frameborder="0"></iframe>
</div>
</body>
</html>
//JS code ----
var tag = document.createElement('script');
tag.src = "https://www.youtube./iframe_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
var player;
var width = document.getElementById("video-id-first").getAttribute("width");
var height = document.getElementById("video-id-first").getAttribute("height");
var src = document.getElementById("video-id-first").getAttribute("src");
//splitting to get the videoId from src.
var partsArr = src.split("/");
var videoSource = partsArr[partsArr.length -1 ].split("?");
var videoId = videoSource[videoSource.length -2 ];
function onYouTubeIframeAPIReady() {
player = new YT.Player('vidWrapper', {
height:height,
width: width,
videoId: videoId,
events: {
'onStateChange': function(event) {
if (event.data == YT.PlayerState.PLAYING) {
startVideo();
}
if (event.data == YT.PlayerState.PAUSED) {
stopVideo();
}
}
}
});
}
function startVideo() {
//write your functionality here.
alert('Video Started');
}
function stopVideo() {
//write your functionality here.
alert('Video Paused');
}
Below is my whole source code for react-native-webview
, it works for me:
source={{
html: `<html><head><meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
img {width: ${screenWidth - 70}}
${customfonts.toString()}
body{
font-family: 'Segoe UI';
font-size: ${fontScale * font14}px;
color: ${colors.PLACEHOLDER_COLOR};
}
h4{
font-size: ${fontScale * font18}px;
}
</style>
</head>
<body>
<script>
// Callback function when the YouTube IFrame API is ready
function onYouTubeIframeAPIReady() {
var iframes = document.querySelectorAll('iframe');
iframes.forEach(function(iframe) {
var width = iframe.width;
var height = iframe.height;
var src = iframe.src;
if(src?.toLowerCase()?.includes("youtube.")){
// Splitting to get the videoId from src.
var partsArr = src.split('/');
var videoSource = partsArr[partsArr.length - 1].split('?');
var videoId = videoSource[videoSource.length - 2 ];
// Create a new div to contain the player
var div = document.createElement('div');
div.id = 'player-' + videoId ? videoId : videoSource; // Unique ID for each player container
iframe.parentNode.replaceChild(div, iframe);
// Create the YouTube player
new YT.Player(div.id, {
height: 180,
width: ${screenWidth - 70},
videoId: videoId ? videoId : videoSource,
events: {
'onReady': function(event) {},
'onStateChange': function(event) {
if (event.data == YT.PlayerState.PLAYING) {
window.ReactNativeWebView.postMessage(JSON.stringify({height: document.body.scrollHeight,isPlaying: true, src: src}))
}
}
}
});
}
});
}
</script>
<script>
// Load the YouTube IFrame API script
var tag = document.createElement('script');
tag.src = "https://www.youtube./iframe_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
</script>
${detailsData.description}
</body></html>`,
}}
本文标签: javascriptPossible to add an onclick event to a YouTube iframeStack Overflow
版权声明:本文标题:javascript - Possible to add an onclick event to a YouTube iframe? - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743738756a2530497.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论