用JS实现歌词与播放音乐同步

用JS实现歌词与播放音乐同步

第一步:把歌词解析成JS对象

参看我的上一篇文章:用JS解析LRC格式的歌词
解析后的歌词写到页面的一个列表中,效果如下:
音乐播放器
主要HTML代码:

<!-- 播放器 -->
<audio id="audio" src="media/沙漠骆驼 - 展展与罗罗.mp3" controls preload="auto"></audio>
<!-- 歌词 -->
<div class="lyric_area">
	<ul id="lyric"></ul>
  • 22
    点赞
  • 70
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
实现音乐歌词同步可以借助 HTML5 的 `<audio>` 标签JavaScript。 首先,需要将歌词文本保存到一个数组中,每一行歌词对应一个数组元素。同时,将每一行歌词的时间戳也保存到一个数组中,时间戳的格式可以是秒数或者毫秒数。 然后,使用 `<audio>` 标签加载音乐文件,并通过 JavaScript 监听 `<audio>` 标签的 `timeupdate` 事件,获取当前播放时间,根据当前时间匹配歌词数组中对应的时间戳,找到当前应该显示的歌词。 最后,将当前歌词显示在页面中,可以使用 `<div>` 标签或者 `<p>` 标签,样式可以通过 CSS 进行设置。同时,为了美观和易于阅读,可以将当前歌词高亮显示,并将其它歌词以灰色显示。 下面是一个简单的示例代码: HTML: ```html <audio id="music" src="music.mp3"></audio> <div id="lyrics"></div> ``` JavaScript: ```javascript var lyrics = [ {time: 0, text: "Verse 1 is here"}, {time: 10, text: "Chorus 1 is here"}, {time: 20, text: "Verse 2 is here"}, {time: 30, text: "Chorus 2 is here"}, {time: 40, text: "Bridge is here"}, {time: 50, text: "Chorus 3 is here"} ]; var music = document.getElementById("music"); var lyricsDiv = document.getElementById("lyrics"); music.addEventListener("timeupdate", function() { var currentTime = music.currentTime; for (var i = 0; i < lyrics.length; i++) { if (currentTime >= lyrics[i].time && (i == lyrics.length - 1 || currentTime < lyrics[i + 1].time)) { lyricsDiv.innerHTML = lyrics[i].text; lyricsDiv.style.color = "#333"; if (i > 0) { var prevLyric = lyricsDiv.previousSibling; prevLyric.style.color = "#999"; } break; } } }); ``` 在这个示例中,歌词数组中包含了多个对象,每个对象包含了一个时间戳和一行歌词。通过监听 `<audio>` 标签的 `timeupdate` 事件,获取当前播放时间,然后遍历歌词数组,找到当前应该显示的歌词,并将其显示在页面中。同时,将前一行歌词的颜色设置为灰色,当前行歌词的颜色设置为黑色。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值