Web制作 × AI

YouTube Player APIを使用してYouTube動画をフルスクリーンで表示するオリジナルボタンを実装する方法

コーディングテクニックの実装内容

今回はWeb制作におけるレスポンシブに対応したYouTubeの埋め込みに関する内容です。YouTube Player APIを使用してYouTube動画をフルスクリーンで表示するオリジナルボタンを実装する方法をご紹介します。また、オリジナルボタンをクリックすることでフルスクリーン表示なり再生もスタートさせるロジックも組み込んでいます。

コーディングテクニックの使いどころ

YouTubeの動画を画面最大サイズでユーザーに閲覧してもらいたい時に有効です。

実装難易度・必要なスキル

コーディングとjQueryの基礎的な知識があれば実務未経験のコーダー、マークアップエンジニア、Webデザイナー、エンジニア、副業の初心者など誰でも実装可能です。

実装所要時間は10分程度

CSS,JavaScriptの記述内容

実装に必要なスクリプトとスタイルはこちらになります。

var tag = document.createElement('script');
tag.src = "https://www.youtube.com/iframe_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
var player, iframe;
var $ = document.querySelector.bind(document);

function onYouTubeIframeAPIReady() {
  player = new YT.Player('player', {
    videoId: 'fgxk6hdHqxE',
    events: {
      'onReady': onPlayerReady
    }
  });
}

function onPlayerReady(event) {
  var player = event.target;
  iframe = $('#player');
  setupListener();
}

function setupListener (){
$('.btn').addEventListener('click', playFullscreen);
}

function playFullscreen (){
  player.playVideo();
  var requestFullScreen = iframe.requestFullScreen || iframe.mozRequestFullScreen || iframe.webkitRequestFullScreen;
  if (requestFullScreen) {
    requestFullScreen.bind(iframe)();
  }
}
.wrap {
  width: 640px;
  margin: 50px auto 0;
}

.movie {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
}

.movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.btn {
  width: 300px;
  margin: 30px auto 0;
  padding: 20px 0;
  text-align: center;
  cursor: pointer;
  color: #fff;
  font-weight: bold;
  background: #c00;
}

@media screen and (max-width:640px) {
  .wrap {
    width: 100%;
  }
}

実装のポイント

準備中

PR
[商品価格に関しましては、リンクが作成された時点と現時点で情報が変更されている場合がございます。]

ChatGPT 120%活用術 [ ChatGPTビジネス研究会 ]
価格:1,390円(税込、送料無料) (2023/5/23時点)


この記事を書いた人(著者情報)

片山

カタチップ編集長。昭和生まれの30代でWeb業界歴は10年以上。現在はカタチップを運用しつつ事業会社でWEBメディアサイトのWebディレクター兼マークアップエンジニアを担当。最近はSNSの運用にも業務範囲を拡大中です。

著者画像

スポンサーリンク