javascript - 使用 jQuery 将不同的视频加载到同一个 div 元素中?

标签 javascript jquery html jquery-mobile html5-video

所以我有一个简单的页面,其中包含一个 div 容器和一个按钮,我希望用户能够点击按钮并将新视频加载到 div 中。

我总共有 8 个视频,页面以自动播放和循环播放视频 1 开始,然后如果用户点击页面底部的按钮,视频 2 将被加载并自动播放和循环播放,直到他们点击按钮再次加载视频 3。

希望这是有道理的!我确信这很容易做到,但我知道这需要几天时间才能弄明白!

任何帮助都会很棒!

这是我的代码,

<div id="vidBox">
    <video width= "977" height= "721" src= "1.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay"</video>
</div>

$("#vidBox").empty().append( video width= "977" height= "721" src= "2.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay" );
$("#vidBox").empty().append( video width= "977" height= "721" src= "3.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay" );
$("#vidBox").empty().append( video width= "977" height= "721" src= "4.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay" );
etc etc etc

这是我更新后的代码

<!DOCTYPE html> 
<html>
<head>
<title>Video Player</title> 
<script type="text/javascript">
    $("document").ready(function () {
    var vid1 = $("<video width= "977" height= "721" src= "1.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay"</video>");
    var vid2 = $("<video width= "977" height= "721" src= "2.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay"</video>");
    var vid3 = $("<video width= "977" height= "721" src= "3.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay"</video>");
    var vid4 = $("<video width= "977" height= "721" src= "4.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay"</video>");
    var vid5 = $("<video width= "977" height= "721" src= "5.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay"</video>");
    var vid6 = $("<video width= "977" height= "721" src= "6.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay"</video>");
    var vid7 = $("<video width= "977" height= "721" src= "7.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay"</video>");
    var vid8 = $("<video width= "977" height= "721" src= "8.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay"</video>");
});
</script>
<script>
    window.myVids = ["1.mp4", "2.mp4", "3.mp4", "4.mp4", "5.mp4", "6.mp4", "7.mp4", "8.mp4"];
</script>
<script>
   var currentIndex = 0;
   var $video = $("#vidBox video");
   $("#myButton").click(function() {
      video.attr("src", myVids[++currentIndex]);
   });
</script>
<link href="style.css" rel="stylesheet" type="text/css">
</head> 
<body>
<div id="vidBox">Content for New Div Tag Goes Here</div>
<button id="myButton">Click Me</button>
</body>
</html>

最佳答案

这是你不想做的事情:)

有一个典型的方法,使用一些数据。 不要在清空区域然后附加内容的地方创建此代码行。如果您查看您的代码,您会发现,除了“src”属性外,其他所有内容都相同。那么,为什么不让事情变得更简单、更可重用。

想想你让来自服务器的一些数据...... 将它们放入 View 中

<script>
    window.myVids = ["1.mp4", "2.mpg", ...];
</script>

现在您在窗口中有一个全局可用的简单数据结构。虽然这不是最佳实践,但现在已经足够了。

现在连接你的按钮,它只会替换 src 属性。我现在不确定,如果您只更改 src 属性,它是否会播放下一部电影,但是您可以自己尝试。

<script>
   var currentIndex = 0;
   var $video = $("#vidBox video");
   $("#myButton").click(function() {
      video.attr("src", myVids[++currentIndex]);
   });
</script>

更新

哦老兄,你的更新看起来很糟糕。好吧,你可能很幸运,我今天过得很愉快......

<!DOCTYPE html> 
<html>
<head>
<title>Video Player</title> 
<script type="text/javascript">
    $("document").ready(function () {
        window.myVids = ["1.mp4", "2.mp4", "3.mp4", "4.mp4", "5.mp4", "6.mp4", "7.mp4", "8.mp4"];
        var currentIndex = 1;
        var $video = $("#vidBox video");
        $("#myButton").click(function() {
             video.attr("src", myVids[++currentIndex]);
        });
    });
</script>
<link href="style.css" rel="stylesheet" type="text/css">
</head> 
<body>
<div id="vidBox">
    <video width= "977" height= "721" src= "1.mp4"  type= "video/mp4" loop= "loop" autoplay="autoplay"></video>
</div>
<button id="myButton">Click Me</button>
</body>
</html>

关于javascript - 使用 jQuery 将不同的视频加载到同一个 div 元素中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17394968/

相关文章:

jquery - jscrollpane 不可见

html - 使用整个导航栏更改字体和颜色时,引导导航栏品牌和链接颜色不匹配

jquery - 了解视口(viewport)外元素的 getBoundingClientRect

javascript - 如何通过javascript更改字体大小

javascript - 尝试迭代时,嵌套 JSON 数组抛出“未定义的 "Uncaught TypeError: Cannot read property ' 长度”

javascript - 使用数据属性拖放嵌套列表顺序

jquery - 向右滚动时背景图像或颜色中断

html - 如何在大屏幕上将此表格居中?

javascript - 溢出隐藏div之外的绝对定位元素

javascript - Angular 办公室织物 ui 表,获取选定的项目