悬停时三种不同的图像和声音

录像带

我有三个图像或div,在悬停时播放的每个图像都分配有声音(环境1-环境3)。到目前为止,它仍然有效。但是,到目前为止,无论我按下image1,image2还是image3,都将播放相同的声音,准确地说是ambience3。我对javascript不太熟悉,所以我猜是js。

另外,当光标离开图像时,我希望声音停止而不是暂停,并在光标再次击中该区域时从头开始。请参见下面的代码:

<body>

  <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>	
  <div id="image1">
      <img class="bottom" src="dcim/20190202_100649 copy.jpg" />
      <img class="top" src="dcim/20190202_100649.jpg" />
      <audio id="audio1">
          <source src="ambience1.mp3"/>
      </audio>
  </div>

  <div id="image2">
      <img class="bottom" src="dcim/20190202_102808 copy.jpg" />
      <img class="top" src="dcim/20190202_102808.jpg" />
      <audio id="audio2">
          <source src="ambience2.mp3"/>
      </audio>
  </div>
		
  <div id="image3">
      <img class="bottom" src="dcim/20190202_101713 copy.jpg" />
      <img class="top" src="dcim/20190202_101713.jpg" />
      <audio id="audio3">
          <source src="ambience3.mp3"/>
      </audio>
  </div>

  <script>
      var audio = $("#audio1")[0];
      $("#image1").mouseenter(function() {
          audio.play();
          audio.loop = true;
      });
      $("#image1").mouseleave(function() {
          audio.pause();
      });
  </script>

  <script>
      var audio = $("#audio2")[0];
      $("#image2").mouseenter(function() {
          audio.play();
          audio.loop = true;
      });
      $("#image2").mouseleave(function() {
          audio.pause();
      });
  </script>

  <script>
      var audio = $("#audio3")[0];
      $("#image3").mouseenter(function() {
          audio.play();
          audio.loop = true;
      });
      $("#image3").mouseleave(function() {
          audio.pause();
      });
  </script>

</body>

卡米尔(KamilKiełczewski)

尝试var audio在每个<script>标签中更改为三个不同的名称(例如下面的代码段(由于缺少图像和声音,因此不起作用)。先前行为的原因是您的audio变量是全局变量,被上一个脚本覆盖。请audio.currentTime = 0;在暂停播放之前使用从头开始的音频

<body>

  <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
		
   <div id="image1">
    <img class="bottom" src="dcim/20190202_100649 copy.jpg" />
    <img class="top" src="dcim/20190202_100649.jpg" />
    <audio id="audio1">
    <source src="ambience1.mp3"/>
    </audio>
  </div>

  <div id="image2">
    <img class="bottom" src="dcim/20190202_102808 copy.jpg" />
    <img class="top" src="dcim/20190202_102808.jpg" />
    <audio id="audio2">
    <source src="ambience2.mp3"/>
    </audio>
  </div>
		
  <div id="image3">
    <img class="bottom" src="dcim/20190202_101713 copy.jpg" />
    <img class="top" src="dcim/20190202_101713.jpg" />
    <audio id="audio3">
    <source src="ambience3.mp3"/>
    </audio>
  </div>

  <script>
    var audio1 = $("#audio1")[0];
    $("#image1").mouseenter(function() {
      audio1.play();
      audio1.loop = true;
    });
    $("#image1").mouseleave(function() {
      audio1.currentTime = 0;
      audio1.pause();
    });
  </script>

  <script>
    var audio2 = $("#audio2")[0];
    $("#image2").mouseenter(function() {
      audio2.play();
      audio2.loop = true;
    });
    $("#image2").mouseleave(function() {
      audio2.currentTime = 0;
      audio2.pause();
    });
  </script>

  <script>
    var audio3 = $("#audio3")[0];
    $("#image3").mouseenter(function() {
      audio3.play();
      audio3.loop = true;
    });
    $("#image3").mouseleave(function() {
      audio3.currentTime = 0;
      audio3.pause();
    });
  </script>

</body>

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章