HTML5列表音乐播放器SMusic

所属分类:媒体-音频和视频

 10009  51  查看评论 (12)
HTML5列表音乐播放器SMusic ie兼容10

SMusic使用方法

这是一款基于HTML5以及CSS3的列表式音乐播放器,增加了列表播放,音量控制,播放进度,播放时间以及播放模式,上一曲,下一曲等功能,已增加歌词功能。采用原生JavaScript编写,不依赖任何库文件,兼容支持html5的浏览器。下载包中的代码已压缩。

可配置参数

参数名类型默认值可选值说明
musicListArray Object[]自定义,格式如[{title:'标题',singer:'歌手',cover:'封面',src:'地址'}] 播放媒体文件列表
defaultVolumeNumber.7自定义,范围在 0 - 1 之间初始化音量值
defaultIndexNumber0
初始化播放索引
autoPlay[1.0.1新增]booleantrue
是否自动播放
defaultMode[1.0.2新增]Number11:列表模式,2:随机模式,3:单曲循环默认播放模式,随机模式优先于defaultIndex
callback[1.0.2新增]Functionfunction (obj) { }
返回当前播放媒体文件信息(Object)

关于歌词

由于涉及AJAX请求,请在服务器环境下演示

目前只支持UTF8编码歌词文件,歌词形式如下:

[offset:0]
[00:00.80]车站 (Live) - 李健
[00:02.21]词:李健
[00:02.96]曲:竹内玛利亚
[00:04.43]
[00:37.57]车窗外恋人相拥
[00:42.62]还在难舍难离
[00:46.08]
[00:47.67]汽笛声突然响起123456789

由于歌词文件需要AJAX加载,目前,只能加载同域文件,如果需要跨域加载歌词,如远程歌词文件,则请自行修改源码(102行)为jsonp请求,这里不会再做更新。

歌词每行高度如果更改(默认30px),请同时修改js源码356行 var top = (i-1) * 30; //30是每个LI的高度

播放器整体样式叫丑,请自行更改CSS文件,注意不要修改类名

CSS

<link rel="stylesheet" href="src/css/smusic.css"/>

HTML

<div class="grid-music-container f-usn">
    <div class="m-music-play-wrap">
        <div class="u-cover"></div>
        <div class="m-now-info">
            <h1 class="u-music-title"><strong>标题</strong><small>歌手</small></h1>
            <div class="m-now-controls">
                <div class="u-control u-process">
                    <span class="buffer-process"></span>
                    <span class="current-process"></span>
                </div>
                <div class="u-control u-time">00:00/00:00</div>
                <div class="u-control u-volume">
                    <div class="volume-process" data-volume="0.50">
                        <span class="volume-current"></span>
                        <span class="volume-bar"></span>
                        <span class="volume-event"></span>
                    </div>
                    <a class="volume-control"></a>
                </div>
            </div>
            <div class="m-play-controls">
                <a class="u-play-btn prev" title="上一曲"></a>
                <a class="u-play-btn ctrl-play play" title="暂停"></a>
                <a class="u-play-btn next" title="下一曲"></a>
                <a class="u-play-btn mode mode-list current" title="列表循环"></a>
                <a class="u-play-btn mode mode-random" title="随机播放"></a>
                <a class="u-play-btn mode mode-single" title="单曲循环"></a>
            </div>
        </div>
    </div>
    <div class="f-cb">&nbsp;</div>
    <div class="m-music-list-wrap"></div>
    <div class="m-music-lyric-wrap">
        <div class="inner">
            <ul class="js-music-lyric-content">
                <li class="eof">暂无歌词... </li>
            </ul>
       </div>
   </div>
</div>

JS调用

<script src="src/js/musicList.js"></script>
<script src="src/js/smusic.js"></script>
<script>
   new SMusic({
        musicList : musicList,
        autoPlay  : true,  //是否自动播放
        defaultMode : 2,   //默认播放模式,随机
        callback   : function (obj) {  //返回当前播放歌曲信息
            console.log(obj);
        }
    });
</script>
相关插件-音频和视频

jQuery MP3播放器插件

jMP3(javaScript的MP3播放器)是一个简单的方法使任何直接的MP3播放上几乎所有的网站.
  音频和视频
 27765  40

移动端H5单视频播放插件zy.media.js

jquery手机端视频播放插件zy.media.js
  音频和视频
 26542  53

扁平html5音乐播放器代码

扁平html5音乐播放器代码
  音频和视频
 19036  28

jQuery仿微信公众号语音框插件weixinAudio.js

jQuery仿微信公众号的语音播放功能weixinAudio.js
  音频和视频
 4655  54

讨论这个项目(12)回答他人问题或分享插件使用方法奖励jQ币

    *源码爱好* 0
    2017/8/9 4:38:03

    急求为什么加载不了歌词??

        *源码爱好*0
        2017/8/9 4:41:07

                cover:'http://127.0.0.1/uploads/allimg/170804/1-1FP4223G30-L.jpg',

        src: 'http://127.0.0.1/uploads/soft/170805/1-1FP5002Q5.mp3',

        lyric  : "http://127.0.0.1/uploads/soft/170805/1-1FP5002Q5.lrc"

        歌曲正常,头像还好,就是歌词网页可以打开。播放不显示。

        *源码爱好*0
        2017/8/9 4:50:29

        已解决。汗必须经过后台,谢谢贴主分享漂亮的播放器。

    回复
    GLAU 0
    2017/5/25 15:00:07

    在哪里修改  可以换成自己要播的歌单?

    回复
    淇实。须臾 0
    2017/3/27 15:54:39

    你好,请问一下如何让音乐列表直接展示所有列表中的音乐,不需要拖动条

    回复
    ghtao 0
    2017/3/24 10:48:24

    怎么播放本地音乐?

    回复
    JQ酷跑 0
    2017/2/24 16:38:54

    歌也要在服务器环境下才可以播放吗?

    回复
    洋芋1993718 0
    2017/1/13 10:01:37

    能不能问一下,怎么增加 下载币?

        yplove1560
        2017/1/13 17:01:17
        想学啊你,我教你啊
        Xtreme-Protector°0
        2017/1/13 18:01:36
        签到呀
        0
        2017/1/13 23:01:32

        签到

        明月半倚深秋0
        2017/1/14 8:23:35

        点击头像,到个人中心,签到3天以上就能获得,而且是连续3天

    回复
取消回复