帮我分析下下面代码的结构跟实现技术 <div id="cd-icon"> <div class="cd-img"></div> <div class="music-list"> <ul> <li class="song">歌曲1</li> <li class="song">歌曲2</li> <li class="song">歌曲3</li> </ul> </div> </div> <audio id="audio" src="./audio/music1.mp3" autoplay></audio>/* js */ // 音乐唱片 (function () { const cdIcon = document.getElementById('cd-icon'); const cdImg = document.querySelector('.cd-img'); const musicList = document.getElementsByClassName('music-list'); const audio = document.getElementById('audio'); let isPlaying = false; const musics = [ './audio/music1.mp3', './audio/music2.mp3', './audio/music3.mp3', ]; let currentSongIndex = 0; console.log(musicList[0].classList); function playSong() { audio.src = musics[currentSongIndex]; audio.play(); let songElements = document.querySelectorAll('.song'); songElements.forEach(function (songElement) { songElement.classList.remove('cur-song'); }); songElements[currentSongIndex].classList.add('cur-song'); } cdIcon.addEventListener('mouseover', function () { musicList[0].classList.add('show'); }); cdIcon.addEventListener('mouseout', function () { musicList[0].classList.remove('show'); }); cdImg.addEventListener('click', function () { if (isPlaying) { audio.pause(); } else { audio.play(); } }); musicList[0].addEventListener('click', function (e) { if (e.target.tagName === 'LI') { let index = Array.prototype.indexOf.call(e.target.parentNode.children, e.target); currentSongIndex = index; playSong(); } }); audio.addEventListener('play', function () { isPlaying = true; cdImg.classList.add('playing'); }); audio.addEventListener('pause', function () { isPlaying = false; cdImg.classList.remove('playing'); }); audio.addEventListener('ended', function () { currentSongIndex++; if (currentSongIndex >= musics.length) { currentSongIndex = 0; } playSong(); }); playSong(); })();
时间: 2024-02-14 21:24:26 浏览: 200
这段代码实现了一个音乐播放器的功能,包括了音乐唱片的旋转效果,歌曲列表和播放控制等功能。
HTML 部分:包括一个 id 为 "cd-icon" 的 div 元素,其中包括一个用于显示唱片图片的 div 元素和一个用于显示歌曲列表的 div 元素。同时,还有一个 id 为 "audio" 的 audio 元素,用于播放音乐。
CSS 部分:没有提供代码,无法分析。
JavaScript 部分:通过获取页面中的各个元素,实现了以下功能:
1. 点击唱片图片可以播放或暂停音乐,同时唱片图片也会进行旋转的动画效果。
2. 当鼠标悬停在唱片图片上时,歌曲列表会显示出来。
3. 当鼠标移出唱片图片时,歌曲列表会隐藏。
4. 点击歌曲列表中的歌曲可以切换歌曲并自动播放。
5. 当音乐开始播放时,唱片图片会进行旋转的动画效果,并且添加一个 "playing" 的类名。
6. 当音乐暂停或者播放结束时,唱片图片的旋转动画会停止,并且移除 "playing" 的类名。
实现技术主要采用了原生的 JavaScript 和 HTML5 的 audio 标签,同时使用了 CSS3 实现了唱片图片的旋转动画效果。
阅读全文