javascript - 带有播放列表的简单音频播放器无法在 IE、Safari 和 Opera 上运行?

标签 javascript jquery

我正在尝试播放播放列表中的音乐。我很喜欢这个

简单播放器

<audio id="audio" preload="auto" tabindex="0" controls="" type="audio/mpeg">
    <source type="audio/mp3" src="music/demo.mp3">
    Sorry, your browser does not support HTML5 audio.
</audio>

播放列表

<ul id="playlist">
  <?php if($lists) { foreach ($lists as $key=> $list) { ?>
    <li class="active">
      <a src="music/<?php  echo $list;  ?>.mp3">
         <?php  echo $list;  ?> </a>
    </li>   
  <?php }}?>
</ul>

JavaScript

var audio;
var playlist;
var tracks;
var current;

init();
function init(){
    current = 0;
    audio = $('audio');
    playlist = $('#playlist');
    tracks = playlist.find('li a');
    len = tracks.length - 1;

    playlist.find('a').click(function(e){
        e.preventDefault();
        link = $(this);
        current = link.parent().index();
        run(link, audio[0]);
    });
    audio[0].addEventListener('ended',function(e){

        if(current == len){
            current = 0;
            link = playlist.find('a')[0];
        }else{
         current++;
            link = playlist.find('a')[current];    

        run($(link),audio[0]);
        }

    });
}
function run(link, player){
        player.src = link.attr('src');
        par = link.parent();
        par.addClass('active').siblings().removeClass('active');
        audio[0].load();
        audio[0].play(); }

不幸的是,播放列表点击事件仅适用于 Firefox 和 Chrome,不适用于 IE、Safari 和 Opera。如何解决?

最佳答案

您是否尝试过使用 href而不是src对于<a>标签?

关于javascript - 带有播放列表的简单音频播放器无法在 IE、Safari 和 Opera 上运行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30784368/

相关文章:

javascript - 如何将 C# DateTime 与 Javascript 的 Date.now() 进行比较

javascript - Firestore 在哪里获取谓词?

javascript - 为什么我的事件处理程序与 jQuery 绑定(bind)不触发?

javascript - jQuery 销毁/禁用/触发一次路点

javascript - AJAX 刷新延迟/不一致

javascript - 如何在 PHP 页面中获取 CSS 开关按钮值?

javascript - 如何用javascript覆盖CSS?

javascript - JShint 警告 : jQuery plugin marked incorrectly 'defined but never used' in AMD

javascript - 在 anchor 标记中触发 OnClick

jQuery 和 TinyMCE : textarea value doesn't submit