日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

html音乐播放器样式,html5扁平化mp3音乐播放器样式代码

發布時間:2024/3/13 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 html音乐播放器样式,html5扁平化mp3音乐播放器样式代码 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

特效描述:html5 扁平化mp3 音樂播放器樣式。扁平風格的簡易的mp3音樂播放器樣式代碼。html5 mp3音樂播放器

代碼結構

1. 引入JS

2. HTML代碼

0:00

0:00

'use strict';

var audioPlayer = document.querySelector('.green-audio-player');

var playPause = audioPlayer.querySelector('#playPause');

var playpauseBtn = audioPlayer.querySelector('.play-pause-btn');

var loading = audioPlayer.querySelector('.loading');

var progress = audioPlayer.querySelector('.progress');

var sliders = audioPlayer.querySelectorAll('.slider');

var volumeBtn = audioPlayer.querySelector('.volume-btn');

var volumeControls = audioPlayer.querySelector('.volume-controls');

var volumeProgress = volumeControls.querySelector('.slider .progress');

var player = audioPlayer.querySelector('audio');

var currentTime = audioPlayer.querySelector('.current-time');

var totalTime = audioPlayer.querySelector('.total-time');

var speaker = audioPlayer.querySelector('#speaker');

var draggableClasses = ['pin'];

var currentlyDragged = null;

window.addEventListener('mousedown', function (event) {

if (!isDraggable(event.target)) return false;

currentlyDragged = event.target;

var handleMethod = currentlyDragged.dataset.method;

this.addEventListener('mousemove', window[handleMethod], false);

window.addEventListener('mouseup', function () {

currentlyDragged = false;

window.removeEventListener('mousemove', window[handleMethod], false);

}, false);

});

playpauseBtn.addEventListener('click', togglePlay);

player.addEventListener('timeupdate', updateProgress);

player.addEventListener('volumechange', updateVolume);

player.addEventListener('loadedmetadata', function () {

totalTime.textContent = formatTime(player.duration);

});

player.addEventListener('canplay', makePlay);

player.addEventListener('ended', function () {

playPause.attributes.d.value = "M18 12L0 24V0";

player.currentTime = 0;

});

volumeBtn.addEventListener('click', function () {

volumeBtn.classList.toggle('open');

volumeControls.classList.toggle('hidden');

});

window.addEventListener('resize', directionAware);

sliders.forEach(function (slider) {

var pin = slider.querySelector('.pin');

slider.addEventListener('click', window[pin.dataset.method]);

});

directionAware();

function isDraggable(el) {

var canDrag = false;

var classes = Array.from(el.classList);

draggableClasses.forEach(function (draggable) {

if (classes.indexOf(draggable) !== -1) canDrag = true;

});

return canDrag;

}

function inRange(event) {

var rangeBox = getRangeBox(event);

var rect = rangeBox.getBoundingClientRect();

var direction = rangeBox.dataset.direction;

if (direction == 'horizontal') {

var min = rangeBox.offsetLeft;

var max = min + rangeBox.offsetWidth;

if (event.clientX < min || event.clientX > max) return false;

} else {

var min = rect.top;

var max = min + rangeBox.offsetHeight;

if (event.clientY < min || event.clientY > max) return false;

}

return true;

}

function updateProgress() {

var current = player.currentTime;

var percent = current / player.duration * 100;

progress.style.width = percent + '%';

currentTime.textContent = formatTime(current);

}

function updateVolume() {

volumeProgress.style.height = player.volume * 100 + '%';

if (player.volume >= 0.5) {

speaker.attributes.d.value = 'M14.667 0v2.747c3.853 1.146 6.666 4.72 6.666 8.946 0 4.227-2.813 7.787-6.666 8.934v2.76C20 22.173 24 17.4 24 11.693 24 5.987 20 1.213 14.667 0zM18 11.693c0-2.36-1.333-4.386-3.333-5.373v10.707c2-.947 3.333-2.987 3.333-5.334zm-18-4v8h5.333L12 22.36V1.027L5.333 7.693H0z';

} else if (player.volume < 0.5 && player.volume > 0.05) {

speaker.attributes.d.value = 'M0 7.667v8h5.333L12 22.333V1L5.333 7.667M17.333 11.373C17.333 9.013 16 6.987 14 6v10.707c2-.947 3.333-2.987 3.333-5.334z';

} else if (player.volume <= 0.05) {

speaker.attributes.d.value = 'M0 7.667v8h5.333L12 22.333V1L5.333 7.667';

}

}

function getRangeBox(event) {

var rangeBox = event.target;

var el = currentlyDragged;

if (event.type == 'click' && isDraggable(event.target)) {

rangeBox = event.target.parentElement.parentElement;

}

if (event.type == 'mousemove') {

rangeBox = el.parentElement.parentElement;

}

return rangeBox;

}

function getCoefficient(event) {

var slider = getRangeBox(event);

var rect = slider.getBoundingClientRect();

var K = 0;

if (slider.dataset.direction == 'horizontal') {

var offsetX = event.clientX - slider.offsetLeft;

var width = slider.clientWidth;

K = offsetX / width;

} else if (slider.dataset.direction == 'vertical') {

var height = slider.clientHeight;

var offsetY = event.clientY - rect.top;

K = 1 - offsetY / height;

}

return K;

}

function rewind(event) {

if (inRange(event)) {

player.currentTime = player.duration * getCoefficient(event);

}

}

function changeVolume(event) {

if (inRange(event)) {

player.volume = getCoefficient(event);

}

}

function formatTime(time) {

var min = Math.floor(time / 60);

var sec = Math.floor(time % 60);

return min + ':' + (sec < 10 ? '0' + sec : sec);

}

function togglePlay() {

if (player.paused) {

playPause.attributes.d.value = "M0 0h6v24H0zM12 0h6v24h-6z";

player.play();

} else {

playPause.attributes.d.value = "M18 12L0 24V0";

player.pause();

}

}

function makePlay() {

playpauseBtn.style.display = 'block';

loading.style.display = 'none';

}

function directionAware() {

if (window.innerHeight < 250) {

volumeControls.style.bottom = '-54px';

volumeControls.style.left = '54px';

} else if (audioPlayer.offsetTop < 154) {

volumeControls.style.bottom = '-164px';

volumeControls.style.left = '-3px';

} else {

volumeControls.style.bottom = '52px';

volumeControls.style.left = '-3px';

}

}

總結

以上是生活随笔為你收集整理的html音乐播放器样式,html5扁平化mp3音乐播放器样式代码的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 鲁一鲁在线 | 美日韩黄色片 | 丁香午夜| 国产女人爽到高潮a毛片 | 中国在线观看免费高清视频播放 | 成人开心网 | 精品一区二区国产 | 中文字幕免费在线观看视频 | 欧美午夜精品 | 狠狠网站| 久久国产精品国语对白 | 午夜福利理论片在线观看 | 最新中文字幕在线播放 | 国产福利视频网站 | 久久99热人妻偷产国产 | 国产123区在线观看 91国产一区二区 | 午夜在线观看视频网站 | 色婷婷777 | 亚洲一区无 | 一本大道伊人av久久综合 | av免 | 中国成熟妇女毛茸茸 | 黄色av一级 | 免费久久网站 | 无码h黄肉3d动漫在线观看 | 免费无遮挡在线观看视频网站 | 裸体按摩www性xxxcom | 激情中文网 | 欧美另类videosbestsex日本 | 国产精品一区二区三区四区五区 | 欧洲视频一区 | 欧美一区二区视频在线观看 | 日韩欧美国产一区二区三区 | 免费观看污 | 青青草国内自拍 | 亚洲av综合av一区二区三区 | 日韩美女视频 | 中国黄色片视频 | 青青超碰| 日韩激情啪啪 | 欧美成人h版| 99久久久久久久久久 | 人人干人人干人人干 | 伊人久久精品一区二区三区 | 四虎影视av | 九九啪| 特黄aaaaaaaaa毛片免 | 嫩草免费视频 | 亚洲福利一区二区 | 亚洲av最新在线网址 | 男生女生搞鸡视频 | 成人网站免费观看 | 99亚洲视频| 夜夜爽www | 日韩在线视频网站 | 夜夜撸av| 人人爱av| 国产一卡二 | 好吊一区 | 日本肉体xxxx裸体xxx免费 | 欧美中文字幕在线观看 | 无码精品黑人一区二区三区 | 亚洲一区二区视频在线观看 | 夜夜激情 | 欧美不卡在线观看 | 精品一卡二卡 | 国产亚洲视频在线观看 | 在线观看欧美精品 | 国产在线精品福利 | 九九九国产视频 | 丰满饥渴老女人hd | 亚洲特黄一级片 | 人妻丰满熟妇av无码区 | 一级片黄色片 | 少妇一级淫片免费放 | 亚洲无遮挡 | 91国在线 | 青青草免费观看 | 麻豆传媒在线视频 | 婷婷91 | 五月婷婷国产 | 男女在线视频 | 一二三区在线视频 | 久久久久久久久久国产 | 大黑人交交护士xxxxhd | 俺去草 | 国产欧美一区二区三区四区 | 国产清纯在线 | av制服丝袜 | 亚洲美女自拍偷拍 | 免费黄色看片 | 高清免费毛片 | 色人阁五月天 | 伊人久久久久久久久久久 | 自拍偷拍亚洲图片 | 日韩精品视频一区二区 | 中文字幕一区二区三区四区欧美 | av午夜影院| 日本一区中文字幕 |