超实用的音乐播放器插件(jquery+css)
2021-03-11 10:32
标签:val idt children mic doc :active live volume storage 通过在网上搜索了大量的音乐播放器插件后,终于找到了一款上手简单,并且效果不错的插件,该音乐播放器插件是通过Jquery+Css实现的,下面就是全部代码,只要遵循下面的步骤,一定可以实现(文章末尾可查看效果图) 一、目录结构
二、导入jquery-1.7.2.min.js、jquery-ui-1.8.17.custom.min.js、mp3 以及 所需要的.png图片 点击右上角的 Fork me on GitHub 到我的GitHub仓库中获取(注意有一些类似播放器上按钮的图片要用我的) 三、index.html 四、style.css 五、script.js 效果如下,即可播放音乐(如果需要调整大小,可以自行修改style.css中的样式)
超实用的音乐播放器插件(jquery+css) 标签:val idt children mic doc :active live volume storage 原文地址:https://www.cnblogs.com/ubiquitousShare/p/12836634.htmlDOCTYPE html>
html lang="en">
head>
meta charset="UTF-8">
title>SpringBoot整合SpringMVCtitle>
script src="js/jquery-1.7.2.min.js">script>
link rel="stylesheet" href="css/style.css">
head>
body>
div id="player">
div class="cover">div>
div class="ctrl">
div class="tag">
strong>Titlestrong>
span class="artist">Artistspan>
span class="album">Albumspan>
div>
div class="control">
div class="left">
div class="rewind icon">div>
div class="playback icon">div>
div class="fastforward icon">div>
div>
div class="volume right">
div class="mute icon left">div>
div class="slider left">
div class="pace">div>
div>
div>
div>
div class="progress">
div class="slider">
div class="loaded">div>
div class="pace">div>
div>
div class="timer left">0:00div>
div class="right">
div class="repeat icon">div>
div class="shuffle icon">div>
div>
div>
div>
div>
ul id="playlist">ul>
script src="js/jquery-ui-1.8.17.custom.min.js">script>
script src="js/script.js">script>
body>
html>
* {
margin: 0;
padding: 0;
}
body {
font: 14px "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif;
background: #333;
color: #fff;
}
a {
outline: none;
text-decoration: none;
}
.left {
float: left;
}
.right {
float: right;
}
.clear {
clear: both;
}
#background {
background: lightblue;
}
#player {
border-radius: 20px;
background: grey;
width: 500px;
height: 130px;
padding: 25px;
margin: 50px auto 30px;
position: relative;
}
#player .cover {
background: rgba(0, 0, 0, 0.5);
border: 1px solid #333;
position: absolute;
top: 25px;
left: 25px;
overflow: hidden;
-moz-border-radius: 10px;
-webkit-border-radius: 10px;
-o-border-radius: 10px;
-ms-border-radius: 10px;
-khtml-border-radius: 10px;
border-radius: 10px;
width: 130px;
height: 130px;
-moz-box-shadow: 0 2px 10px black;
-webkit-box-shadow: 0 2px 10px black;
-o-box-shadow: 0 2px 10px black;
box-shadow: 0 2px 10px black;
}
#player .cover img {
-moz-border-radius: 10px;
-webkit-border-radius: 10px;
-o-border-radius: 10px;
-ms-border-radius: 10px;
-khtml-border-radius: 10px;
border-radius: 10px;
width: 130px;
height: 130px;
}
#player .ctrl {
margin-left: 155px;
text-shadow: 0 1px 2px #000;
line-height: 16px;
}
#player .ctrl .tag strong, #player .ctrl .tag span {
display: block;
text-overflow: ellipsis;
}
#player .ctrl .tag span {
font-size: 12px;
margin-top: 5px;
color: #ccc;
}
#player .ctrl .icon {
background-repeat: no-repeat;
background-position: center;
display: inline-block;
opacity: 0.6;
cursor: pointer;
width: 24px;
height: 24px;
-moz-transition: 0.3s;
-webkit-transition: 0.3s;
-o-transition: 0.3s;
transition: 0.3s;
-moz-user-select: none;
-khtml-user-select: none;
-webkit-user-select: none;
-o-user-select: none;
user-select: none;
}
#player .ctrl .icon:hover, #player .ctrl .icon.enable {
opacity: 1;
}
#player .ctrl .icon:active {
opacity: 0.3;
}
#player .ctrl .control {
margin-top: 10px;
height: 25px;
}
#player .ctrl .control .rewind {
background-image: url(../img/rewind.png);
}
#player .ctrl .control .playback {
background-image: url(../img/play.png);
}
#player .ctrl .control .playback.playing {
background-image: url(../img/pause.png);
}
#player .ctrl .control .fastforward {
background-image: url(../img/fastforward.png);
}
#player .ctrl .control .volume .mute {
background-image: url(../img/volume.png);
}
#player .ctrl .control .volume .mute.enable {
background-image: url(../img/mute.png);
}
#player .ctrl .control .volume .slider {
margin-top: 11px;
margin-left: 10px;
width: 100px;
}
#player .ctrl .progress {
margin-top: 10px;
}
#player .ctrl .progress .timer {
font-size: 12px;
color: #ccc;
margin-top: 8px;
}
#player .ctrl .progress .repeat, #player .ctrl .progress .shuffle {
background-position: center bottom;
}
#player .ctrl .progress .repeat {
background-image: url(../img/repeat.png);
}
#player .ctrl .progress .repeat.once, #player .ctrl .progress .repeat.all {
opacity: 1;
}
#player .ctrl .progress .repeat.once {
position: relative;
}
#player .ctrl .progress .repeat.once:before {
content: "1";
position: absolute;
top: 3px;
right: -2px;
font-size: 8px;
}
#player .ctrl .progress .shuffle {
background-image: url(../img/shuffle.png);
}
.slider {
background: rgba(0, 0, 0, 0.3);
height: 5px;
position: relative;
cursor: pointer;
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
-o-border-radius: 5px;
-ms-border-radius: 5px;
-khtml-border-radius: 5px;
border-radius: 5px;
-moz-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.5) inset;
-webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.5) inset;
-o-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.5) inset;
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.5) inset;
}
.slider:hover a, .slider.enable a {
opacity: 1;
}
.slider a {
background: #fff;
margin-left: -2.5px;
position: absolute;
opacity: 0;
width: 5px;
height: 5px;
-moz-border-radius: 50%;
-webkit-border-radius: 50%;
-o-border-radius: 50%;
-ms-border-radius: 50%;
-khtml-border-radius: 50%;
border-radius: 50%;
-moz-transition: opacity 0.3s;
-webkit-transition: opacity 0.3s;
-o-transition: opacity 0.3s;
transition: opacity 0.3s;
}
.slider .loaded, .slider .pace {
position: absolute;
height: 100%;
opacity: 0.7;
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
-o-border-radius: 5px;
-ms-border-radius: 5px;
-khtml-border-radius: 5px;
border-radius: 5px;
}
.slider .loaded {
background: rgba(255, 255, 255, 0.1);
}
.slider .pace {
background: #258fb8;
}
#playlist {
background: rgba(0, 0, 0, 0.5);
width: 470px;
margin: 0 auto 50px;
padding: 10px 15px;
list-style: none;
position: relative;
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
-o-border-radius: 5px;
-ms-border-radius: 5px;
-khtml-border-radius: 5px;
border-radius: 5px;
-moz-box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);
-webkit-box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);
-o-box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);
}
#playlist li {
color: #aaa;
font-size: 12px;
line-height: 2;
padding-left: 25px;
cursor: pointer;
text-overflow: ellipsis;
-moz-transition: 0.3s;
-webkit-transition: 0.3s;
-o-transition: 0.3s;
transition: 0.3s;
}
#playlist li:hover {
color: #fff;
}
#playlist li.playing {
background: url(../img/playing.png) no-repeat 0 center;
color: #fff;
font-weight: bold;
}
footer {
position: relative;
font-size: 12px;
color: white;
margin-top: 160px;
text-shadow: 0 1px 2px #000;
text-align: center;
}
footer a {
color: #fff;
font-weight: bold;
}
footer a:hover {
text-decoration: none;
}
(function ($) {
// Settings
var repeat = localStorage.repeat || 0,
shuffle = localStorage.shuffle || ‘false‘,
continous = true,
autoplay = true,
playlist = [
{
title: ‘像我这样的人‘,
artist: ‘毛不易‘,
album: ‘像我这样的人.mp3‘,
cover: ‘img/像我这样的人.gif‘,
mp3: ‘mp3/毛不易-像我这样的人(Live).mp3‘,
ogg: ‘‘
},
{
title: ‘追梦人‘,
artist: ‘阿木‘,
album: ‘追梦人.mp3‘,
cover: ‘img/追梦人.gif‘,
mp3: ‘mp3/追梦人.mp3‘,
ogg: ‘‘
},
{
title: ‘阿刁‘,
artist: ‘赵雷‘,
album: ‘阿刁.mp3‘,
cover: ‘img/阿刁.gif‘,
mp3: ‘mp3/阿刁.mp3‘,
ogg: ‘‘
}];
// Load playlist
for (var i = 0; i ) {
var item = playlist[i];
$(‘#playlist‘).append(‘