HTML+JS+CSS歌词滚动效果

这篇具有很好参考价值的文章主要介绍了HTML+JS+CSS歌词滚动效果。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

代码下载:【免费】HTML+JS+CSS歌词滚动效果资源-CSDN文库

一些代码说明:

 初始化歌词数据和时间字符串转换为秒数:

// 初始化歌词数据
const initWords = () => {
  let lines = lrc.split('\n');
  let res = [];
  lines.forEach(item => {
    let parts = item.split(']');
    let timeStr = parts[0].substring(1);
    let obj = {
      time: parseTime(timeStr), // 调用 parseTime 函数将时间字符串转换为秒数
      words: parts[1]
    };
    res.push(obj);
  });
  return res;
};

// 时间字符串转换为秒数
const parseTime = (timeStr) => {
  let parts = timeStr.split(':');
  let time = +parts[0] * 60 + +parts[1];
  return time;
};

let lrcData = initWords(); // 调用初始化歌词数据函数

获取当前显示歌词下标:

// 得到当前显示歌词下标
const findIndex = () => {
  let curTime = doms.audio.currentTime;
  for (let i = 0; i < lrcData.length; i++) {
    if (curTime < lrcData[i].time) {
      return i - 1;
    }
  }
  return lrcData.length - 1;
};

歌词元素显示:

// 歌词元素显示
const creatLrcElements = () => {
  let frag = document.createDocumentFragment(); // 创建文档片段
  for (let i = 0; i < lrcData.length; i++) {
    let li = document.createElement('li');
    li.textContent = lrcData[i].words;
    frag.appendChild(li);
  }
  doms.ul.appendChild(frag); // 将文档片段添加到 ul 元素中
};
creatLrcElements();

设置偏移和滚动事件监听器:

// 设置偏移
const setOffset = () => {
  let index = findIndex();
  let offset = liHeight * index + liHeight / 2 - containerHeight / 2;
  if (offset < 0) {
    offset = 0;
  } else if (offset > maxHeight) {
    offset = maxHeight;
  }
  doms.ul.style.transform = `translateY(-${offset}px)`;

  let li = doms.ul.querySelector('.active');
  if (li) {
    li.classList.remove('active');
  }
  li = doms.ul.children[index];
  if (li) {
    li.classList.add('active');
  }
};

doms.audio.addEventListener('timeupdate', setOffset); // 监听音频播放时间更新事件

// 添加滚动事件监听器
doms.container.addEventListener('wheel', function(event) {
  var deltaY = event.deltaY; // 获取滚动的垂直方向位移
  doms.container.scrollTop += deltaY; // 根据滚动位移调整列表的滚动位置
  event.preventDefault(); // 阻止页面滚动
});

这些代码主要实现了歌词的初始化、显示和随音频播放的同步滚动。其中,initWords 函数用于将歌词字符串解析成数据数组,parseTime 函数用于将时间字符串转换为秒数。通过 setOffset 函数实现歌词的滚动和高亮显示。最后,添加了一个滚动事件监听器,以便用户通过滚动调整歌词显示位置。

注意:

文章说明:该功能是根据“渡一前端”视频敲出来的,并不属于原创,但是转载或是翻译的连接我找不到了,所以使用的原创标签,特此说明一下。文章来源地址https://www.toymoban.com/news/detail-799213.html

到了这里,关于HTML+JS+CSS歌词滚动效果的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • WEB前端3D变换效果以及如何应用js代码

    变换效果3d 过渡属性 动画 首先JavaScript是一个 动态的解释型 编程语言。 所谓动态就是指,代码在运行时变量的数据类型可以发生变化。(静态就想类似c、java、go这种语言他们需要创建变量时就确定变量的数据类型,并且不可随意更改) 所谓的解释型语言,是指代码运行时

    2024年01月23日
    浏览(34)
  • 博客无限滚动加载(html、css、js)实现

    这是一个简单实现了类似博客瀑布流加载功能的页面,使用html、css、js实现。简单易懂,值得学习借鉴。👍 演示地址:https://i_dog.gitee.io/easy-web-projects/infinite_scroll_blog/index.html index.html style.css script.js 该项目从github中的vanillawebprojects仓库收集。 原始代码: 原始代码地址 https

    2024年02月07日
    浏览(30)
  • 用纯HTML,JS,CSS实现横向滚动标签页

    前不久,在我的一个项目中,需要展示一个横向滚动的标签页,它支持鼠标横向拖动和点击切换。在实现的过程中,我发现这个小功能需要同时用到前端的三辆马车,但是实现难度不高,而且最终效果还不错,是个难得的初学者项目,于是萌生了写这篇文章的想法,希望对初

    2024年02月08日
    浏览(37)
  • web前端大作业_Html5+CSS3+JS原生项目_京东商城首页 详细代码

    index.html css index.css js index.js 效果图如下:            

    2024年02月11日
    浏览(46)
  • vue-codemirror实现一个前端代码在线编辑器,可处理 HTML,VUE,JS,CSS代码在线编辑

    先找个目录创建一个vue项目 例如 我们想要项目叫 editor 在终端执行 2和3其实都可以 但个人建议 最近还是2会更稳定一些 在终端执行 引入依赖包 然后在项目src目录下创建 utils 文件夹 里面创建一个setting.js 参考代码如下 然后 这边 调用组件的代码 因为项目也刚创 我直接写 s

    2024年02月15日
    浏览(39)
  • 前端常用js、css效果

    效果 主要整理了几个常用的,方便平时做项目的时候参考 文本横向滚动 文本无限滚动 无缝轮播 无缝滚动 盒子上下滚动 樱花飘落效果 参考代码 文本横向滚动 文本无限滚动 无缝轮播 无缝滚动 盒子上下移动 樱花飘落 添加插件sakura.js就可以了,不用什么代码

    2024年02月02日
    浏览(31)
  • CSS样式前端HTML页面常用CSS效果实现及其相关配置信息------前端入门基础教程

    !DOCTYPE html !-- 这是HTML的注释 -- html lang=\\\"en\\\" id=\\\"myHtml\\\"     head         !-- 这里不是设置了编码,而是告诉浏览器,用什么编码方式打开文件避免乱码 --         meta charset=\\\"UTF-8\\\"         meta name=\\\"viewport\\\" content=\\\"width=device-width, initial-scale=1.0\\\"         titleHtmlAll/title         

    2024年02月05日
    浏览(38)
  • 有趣的HTML实例(十一) 烟花特效(css+js)

    为什么今天不做炒土豆丝呢,为什么呢为什么呢为什么呢为什么呢,坚持问上一个时辰,一般来说,第二天我们的饭桌上就会出现炒土豆丝。这件事告诉了我们求知欲的重要性,知之才幸福,不知不幸福。 ——《华胥引》 目录 一、前言 二、往期作品回顾 三、作品介绍 四、

    2024年02月03日
    浏览(42)
  • 用HTML、CSS和JS打造绚丽的雪花飘落效果

    目录 一、程序代码 二、代码原理 三、运行效果 这段代码主要通过JavaScript来操作DOM元素,实现了一个下雪的效果。首先,通过CSS样式设置整个页面的背景为黑色,并且创建一个id为\\\"box\\\"的容器元素用于容纳雪花。 接着,使用JavaScript代码自执行函数来封装雪花的相关逻辑。在

    2024年02月19日
    浏览(30)
  • 前端(HTML + CSS + JS)

    HTML是超文本标记语言,超文本是指文本、声音、图片、视频、表格、链接等等。标记表示由许许多多的标签组成。HTML页面是运行到浏览器上的。 (1)HTML 文件基本结构 html 标签是整个 html 文件的根标签(最顶层标签) head 标签中写页面的属性 body 标签中写的是页面上显示的内

    2024年02月05日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包