Как динамически воспроизводить видео на основе нажатой кнопки - PullRequest
0 голосов
/ 25 апреля 2019

Здравствуйте, у меня есть трейлер с двумя кнопками и фильм, я хочу воспроизвести видео на основе нажатой кнопки.

Например, я выбираю трейлер, тогда он должен играть трейлер, и наоборот

вот моя кнопка

 <button class="btn btn-sm btn-dark" id="trailer" data-toggle="modal" data-target="#myModal2">Trailer</button>

 <button class="btn btn-sm btn-dark" id="movieNoads" data-toggle="modal" data-target="#myModal2">Movie</button>

вот мойвидеоплеер и его javascript коды

 <video controls playsinline id="player" width="100%">

      <script type="text/javascript">

        var video = document.getElementById('video');
        var source = document.createElement('source');

         document.getElementById('trailer').onclick = function () {

            source.setAttribute('src', '../inflightapp/storage/app/public/trailer_videos/<?php echo ''.$row2['trailer_video'].''; ?>');
            video.appendChild(source);
            video.play();

          }


          document.getElementById('movieNoads').onclick = function () {
              source.setAttribute('src', '../inflightapp/storage/app/public/movie_videos/<?php echo ''.$row2['movie_video'].''; ?>');
            video.appendChild(source);
            video.play();
          }

      </script>

    </video>

Ответы [ 4 ]

0 голосов
/ 25 апреля 2019

Добро пожаловать в переполнение стека.Вы можете попробовать что-то вроде следующего:

Я использовал jQuery и Bootstrap (как я заметил, вы использовали элементы Bootstrap HTML).

//Custom function to populate a modal. This could be expanded on to even add a destination parameter in order to use seperate modals (e.g. function videoModal(destination, source) and replace #myModal2 with the `destination` parameter).
function videoModal(source) {
  $("#myModal2 .modal-body").html($("video#player").clone());
  //Add your second source:
  $("#myModal2 video#player > source").attr("src", source);
  $("#myModal2 .modal-body video#player").css("display", "block");
}

$(document).ready(function() {
  //On init, save current loaded state of modal
  let modalInit = $("#myModal2 .modal-body").html();

  //On interaction with a control
  $("body").on("click", "button#trailer", function() {
    //Populate modal
    videoModal("https://www.w3schools.com/tags/movie.mp4");
  });

  $("body").on("click", "button#movieNoads", function() {
    //Populate modal
    videoModal("https://www.w3schools.com/html/mov_bbb.mp4")
  });

  //Reset modal on close
  $("#myModal2").on('hidden.bs.modal', function(e) {
    $("#myModal2 .modal-body").html(modalInit);
  });
});
video#player {
  display: none;
  margin-left: auto;
  margin-right: auto;
}
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" rel="stylesheet" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"></script>
<!-- Modal -->
<div class="modal fade" id="myModal2" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <h5 class="modal-title" id="exampleModalLabel">Modal title</h5>
        <button type="button" class="close" data-dismiss="modal" aria-label="Close">
          <span aria-hidden="true">&times;</span>
        </button>
      </div>
      <div class="modal-body">
        ...
      </div>
      <div class="modal-footer">
        <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
        <button type="button" class="btn btn-primary">Save changes</button>
      </div>
    </div>
  </div>
</div>

<video id="player" controls autoplay loop>
  <source src="" type="video/mp4">
</video>

<!-- Button trigger modal -->
<button type="button" id="trailer" class="btn btn-primary" data-toggle="modal" data-target="#myModal2">
  Trailer
</button>

<button type="button" id="movieNoads" class="btn btn-primary" data-toggle="modal" data-target="#myModal2">
  Movie
</button>

JSFiddle

Таким образом, вы также можете загружать видео внутри модалов (как я заметил, вы былипытаясь использовать модальные кнопки).Обновления не требуются.

0 голосов
/ 25 апреля 2019

Вы забыли load видео

"use strict";

console.clear();

const video = document.getElementById("player");
const source = document.createElement("source");

function loadVideo(element, src) {
  source.src = src;
  element.appendChild(source);
  element.load();
  element.play();
}

document.getElementById("trailer").addEventListener(
  'click',
  () => loadVideo(
    video,
    "https://s3-us-west-2.amazonaws.com/s.cdpn.io/96344/lego.mp4"
  )
)

document.getElementById("movieNoads").addEventListener(
  'click',
  () => loadVideo(
    video,
    "https://s3-us-west-2.amazonaws.com/s.cdpn.io/96344/abstract-001.mp4"
  )
)
<button class="btn btn-sm btn-dark" id="trailer" data-toggle="modal" data-target="#myModal2">Trailer</button>

<button class="btn btn-sm btn-dark" id="movieNoads" data-toggle="modal" data-target="#myModal2">Movie</button>

<video controls playsinline id="player" width="100%" loop></video>
0 голосов
/ 25 апреля 2019

Вы можете попробовать это

function setvideo(src) {
    document.getElementById('div_video').innerHTML = '<video autoplay controls id="video_ctrl" style=" width: 100%;"><source src="'+src+'" type="video/mp4"></video>';
    document.getElementById('video_ctrl').play();
}
<!DOCTYPE html>
<html>
<body>

<div id="div_video"> </div>
<button onClick="setvideo('movie.mp4')"> Trailer</button>
<button onClick="setvideo('mov_bbb.mp4')"> Movie</button>




</body>
</html>
0 голосов
/ 25 апреля 2019

Вы можете взглянуть на это.

<button class="btn btn-sm btn-dark" id="trailer">Trailer</button>

<button class="btn btn-sm btn-dark" id="movieNoads">Movie</button>

<script type="text/javascript"> 

    var trailer = document.getElementById('trailer');
    trailer.setAttribute('data-toggle', 'modal'); 
    trailer.setAttribute('data-target', '#myModal2');

   var movieNoads = document.getElementById('movieNoads');
   movieNoads.setAttribute('data-toggle', 'modal'); 
   movieNoads.setAttribute('data-target', '#myModal2');
</script>
 
 <video controls playsinline id="player" width="100%">

      <script type="text/javascript">

        var video = document.getElementById('player');

         document.getElementById('trailer').onclick = function () {
            document.getElementById("player").style.display = "block";
            video.setAttribute('src', 'YouVideoURLHere');
            video.play();

          }


          document.getElementById('movieNoads').onclick = function () {               document.getElementById("player").style.display = "block";
            video.setAttribute('src', 'YourVideoURLHere');
            video.play();
          }
      document.getElementById("player").style.display = "none";

      </script>

    </video>
...