🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

YouTube API

YouTube APIはYouTubeのビデオコンテンツと機能性をウェブサイト、アプリケーション、デバイスに統合することを可能にします。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

1回答

2252閲覧

非表示display:noneの際のYoutubeIframeAPIがうまくいかない

harapara

総合スコア39

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

YouTube API

YouTube APIはYouTubeのビデオコンテンツと機能性をウェブサイト、アプリケーション、デバイスに統合することを可能にします。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2020/12/24 04:05

Youtubeを2つ用意しW769以上は①を、768W以下は②を表示するようにしています。
2つともミュートの自動再生で、例えばW769以上で①の音を手動で出し、
サイズをW768以下に変更したら①はミュートになるようにしたくコード書きました。
以下の挙動があり、解決策を探っています。
何か問題、ご提案あればご教授いただけると幸いです。

問題1
Ipad実機(safari、Chrome)
初期のサイズで表示される動画はミュートの自動再生なのですが
そこからサイズを変え(縦横のデバイスの向き)①②の表示非表示が入れ替わると新たに表示された方は動画が再生されず、再生してもミュートにはなっていません。
ミュートになっていないから自動再生されていないのでしょうか。

問題2
Android(Chrome)、PCデベロッパーツールでのIpadやIphone(Chrome)
他ページから動画のページに遷移すると非表示のPC用動画①の音が出る(リロードすると音はならない)

いずれにしろ非表示の方のYoutubeがうまく動きません、、

HTML

1<section class="top"> 2 <div class="top__yt"><div id="js-player"></div></div> 3</section> 4<section class="top-pr tb_show"> 5 <div class="top-pr__yt"><div id="js-player2"></div></div> 6</section>

CSS

1.tb_show{ 2 display: none; 3} 4.top__yt,.top-pr__yt { 5 position: relative; 6 width: 100%; 7 padding-top: 56.25%; 8} 9.top__yt #js-player, 10.top-pr__yt #js-player2{ 11 position: absolute; 12 top: 0; 13 right: 0; 14 width: 100% !important; 15 height: 100% !important; 16} 17@media (max-width: 768px){ 18 .tb_show{ 19 display: block; 20 } 21 .top__yt{ 22 display: none; 23 } 24}

js

1 $("body").append('<script src="https://www.youtube.com/iframe_api">'); 2 let ytPlayer =[]; 3 var ytData = [ 4 { 5 area: 'js-player' 6 }, { 7 area: 'js-player2' 8 } 9 ]; 10 11 setTimeout(function onYouTubeIframeAPIReady() { 12 13 for(var i = 0; i < ytData.length; i++) { 14 ytPlayer[i] = new YT.Player( 15 ytData[i]['area'], 16 { 17 videoId: "YouTube ID", 18 playerVars: { 19 loop: 1, 20 autoplay: 1, 21 rel: 0, 22 controls: 1, 23 modestbranding: 1, 24 widgetid: 1, 25 playsinline: 1, // スマホでも自動再生 26 showinfo: 0 27 }, 28 events: { 29 onReady: onPlayerReady, 30 onStateChange: onPlayerStateChange, // プレーヤーの再生、一時停止、終了したとき 31 }, 32 }); 33 function onPlayerReady(event) { 34 event.target.mute(); 35 event.target.playVideo(); 36 } 37 function onPlayerStateChange(event) { 38 if (event.data == YT.PlayerState.ENDED) { 39 event.target.playVideo(); 40 } 41 } 42 $(window).on('resize', function() { //リサイズ時 43 var windowWidth = window.innerWidth; 44 45 if (windowWidth > 768) { 46 ytPlayer[1].mute(); 47 ytPlayer[0].playVideo(); 48 } else{ 49 ytPlayer[0].mute(); 50 ytPlayer[1].playVideo(); 51 } 52 }); 53 } 54 }, 800);

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

display: none;が原因のようなので、高さをなくしopacity:0で対応しました。

投稿2020/12/24 13:19

harapara

総合スコア39

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問