HTML5的最強之處莫過於對媒體檔案的處理,如利用一個簡單的vedio標籤就可以實現影片播放。類似地,在HTML5中也有對應的處理音頻文件的標籤,那就是audio標籤
HTML5出來這麼久了,但是關於它裡面的audio標籤也就用過那麼一次,當然還僅僅只是把這個標籤插入到了頁面中。這次呢就剛好趁著幫朋友做幾個頁面,拿這個audio標籤來練練手。
首先你需要在頁面中插入一個audio標籤,注意這裡最好不要設定loop='loop',這個屬性使用來設定循環播放的,因為到後面需要使用ended屬性的時候,如果loop被設定為loop的話,ended屬性將永遠是false。
autoplay='autoplay'設定頁面載入後自動播放音樂,preload和autoplay屬性的作用是一樣的,如果標籤中出現了autoplay屬性,那麼preload屬性將被忽略。
controls='controls'設定顯示音樂的控制條。
有了這個標籤之後,那麼恭喜你,你的頁面已經可以播放音樂了。但這樣會不會顯得頁面太過於單調了,於是我又為頁面添加了一些東西,讓歌詞能夠同步的顯示在頁面上,還能夠選擇要播放的音樂。那麼先要做成這樣的效果,我們就得要去下載一些lrc格式的歌詞文件,然後你需要把這些音樂格式化一番。因為剛開始的音樂檔案是這樣的
XML/HTML Code
複製內容到剪貼簿
- //歌詞同步部分
- function parseLyric(text) {
- //將文字分隔成一行一行,存入數組
-
var lines = text.split('n'), 🎜>.split('n'), 🎜>
- //用於配對時間的正規表示式,配對的結果類似[xx:xx.xx]
-
pattern = /[d{2}:d{2}.d{2}]/g,
- //儲存最終結果的陣列
-
result = [];
- //去掉不含時間的行
- while (!pattern.test(lines[0])) {
-
lineslines = lines.slice(1);
- };
- //上面用'n'產生生成數組時,結果中最後一個為空元素,這裡將去掉
- lines[lines.length - 1].length === 0 && lines.pop();
lines.forEach(function(v /*陣列元素值*/ , i /*元素索引*/ , a /*陣列本身*/ ) {
-
//抽取時間[xx:xx.xx] -
var -
time = v.match(pattern),
//拿歌詞
v-
value = v.replace(pattern, '');
//因為一行裡面可能有多個時間,所以time有可能是[xx:xx.xx][xx:xx.xx][xx:xx.xx]的形式,需要進一步分隔
-
time.forEach(function(v1, i1, a1) {
-
//去掉時間裡的中括號得到xx:xx.xx
-
var
- t = v1.slice(1,-1).split (':');
//將結果壓入最終陣列
-
result.push([parseInt(t[0], 10) * 60 parseFloat(t[1]), value]);
-
});
-
});
-
//最後將結果數組中的元素按時間大小排序,以便保存之後正常顯示歌詞
-
result.sort(function(a, b) {
-
return a[0] - b[0];
-
});
-
return result;
-
}
-
到了這裡我們就能夠很容易的使用每首音樂的歌詞了,我們需要有一個function來獲得歌詞,並且讓他同步的顯示在頁面上,能夠正常的切換音樂。下面附上程式碼。
複製內容到剪貼簿
- function fn(sgname){
- $.get('music/' sgname '.lrc',function(data){
-
var str=parseLyric(data));
for(var -
i=0,li;i,li;i str.length
;i ){ -
li=$('li>li>li>>
li-
>>
li-
>>
' str[i][1] '-
li>');
$('#gc ul').append(li); -
}
$('#aud')[0].ontimeupdate=function(){//視屏音訊目前的播放位置改變時觸發
for (var i = 0
= -
str.length; i
- l
- l
- l
- l
- l
- l
- l
-
if (this.currentTime /*目前播放的時間*/ > str[i][0]) {
str[i][0]) { -
//顯示到頁
$('#gc ul').css('top',-i*40 200 'px'); //讓歌詞往上移動
$('#gc ul li').css('color','#fff');
$('#gc ul li:nth-child(' (i 1) ')').css('color','red'); //高亮顯示目前播放的哪一句歌詞
-
}
}
-
if(this.ended){ //判斷目前播放的音樂是否播放完畢
var
- songslen=$('.songs_list li').length;
for(var i=
- 0,val;i0,val;i
-
songslen- ;i ){
val- =$('.songs_list li:nth-child(' (i 1) ')').text();
-
if(
- val==sgname){
-
- i=(
- i==(songslen-1))?1:i 2; >
sgname
=$('.songs_list li:nth-child(' i ')').text(); //音樂播放完畢後切換下一首音樂
$('#gc ul').empty(); //清空歌詞
$('#aud').attr('src','music/' sgname '.mp3');
fn(sgname);
return;
}
}
}
};
});
} fn($('.songs_list li:nth-child(1)').text());
那麼到了這裡你的音樂歌詞已經能夠正常的同步顯示在頁面上了。不過還缺少一個東西,就是一個音樂的列表,我希望能夠點擊這個列表裡的音樂,從而播放該音樂,下面附上程式碼。 HTML程式碼
XML/HTML Code複製內容到剪貼簿
- div 類=class=class=
- >
ul class=
class-
=>
li>昨天再一次
- 李>
li>你很美
- 你很美你很美 李>
-
ul>
按鈕 class=class=" 🎜>>點br/>
br/>我按鈕>-
div>
div id=id=id=id-
=id=id 🎜>>
ul>
>>>>
div>
css代碼
XML/HTML 程式碼將內容複製到剪貼簿
- #gc{
- 寬度:400 像素;
- 高度:400 像素;
- 背景:透明;
- 邊距:100 像素自動;
- 顏色:#fff;
- 字體大小:18px;
- 溢位:隱藏;
- 職位:親;
- }
- #gc ul{
- 位置:絕對;
- 上:200 像素;
- }
- #gc ul li{
- 文字對齊:居中;
- 高度:40 像素;
- 高價:40px;
- }
- .songs_cnt{
- 浮動:左;
- 頁邊距:200px;
- 職位:親;
- }
- .songs_list{
- 背景顏色:rgba(0,0,0,.2);
- 邊框半徑:5px;
- 浮動:左;
- 寬度:250 像素;
- 內邊距:15px;
- 左邊距:-280px;
- }
- .songs_list li{
- 高度:40 像素;
- 高價:40px;
- 字體大小:16px;
- 顏色:rgba(255,255,255,.8);
- 遊標:指針;
- }
- .songs_list li:hover{
- 字體大小:20px;
- 顏色:rgba(255,23,140,.6);
- }
- .sel_song{
- 位置:絕對;
- 上:50%;
- 寬度:40 像素;
- 高度:80 像素;
- 頁邊距:-40px;
- 字體大小:16px;
- 文字對齊:居中;
- 背景顏色:透明;
- 邊框:1px 實心#2DCB70;
- 字體粗細:粗體;
- 遊標:指針;
- 邊框半徑:3px;
- 字體系列:sans-serif;
- 過渡:全部 2 秒;
- -moz-transition:全部 2;
- -webkit-transition:全部 2;
- -o-transition:全部 2;
- }
- .sel_song:hover{
- 顏色:#fff;
- 背景顏色:#2DCB70;
- }
- .songs_list li.active{
- 顏色:#f00;
- }