上一期我们介绍了外观设计,这把我们聊聊让进度条跟随播放进度走
目录
预期效果
准备
- 在此之前,你需要有以下基础:
- HTML/CSS/JS
- 了解一些<audio>标签的属性和事件
- Vue(数据绑定和事件绑定)
实现
- 还是上次的那个Html/css,但我们这把加入了:
- 最外围用div包裹,用于创建vue
- 添加了<audio>
- 显示音乐标签面板 (controls)
- 默认静音 (muted)
- 绑定事件:播放时长更新事件 timeupdate
- 绑定数据:音频文件资源链接 src
- 两个vue数据绑定
- cmusic_control_loadProgress_style (加载进度条长度)
- cmusic_control_progress_style (播放进度条长度)
- 修改部分css样式
- HTML:
<div id="root_div" class="cmusic_displayFlex_class" style="height:150px;justify-content:space-between;align-items: center;">
<!-- 音频 -->
<audio id="cmusic_audio" ref="cmusic_audio" controls muted
@timeupdate="audio_lengthChange()" :src="url_audio">
</audio>
<span id="cmusic_control_span_progressBar">
<div class="cmusic_displayFlex_class cmusic_control_progress_div" style="flex-direction: row;">
<span id="cmusic_control_span_loadProgress" :style="cmusic_control_loadProgress_style"></span>
<span id="cmusic_control_span_progress" :style="cmusic_control_progress_style"></span>
</div>
</span>
<div>
- CSS:
<style>
/*外框*/
#cmusic_control_span_progressBar{
border-radius: 50px;
height: 20px;
width: 100%;
display: inline-flex;
align-items: center;
position: relative;
background: transparent;
box-shadow: inset 2px 2px 4px #bcc5d6,
inset -2px -2px 5px #feffff;
border: 2px solid #d0f4ff;
justify-content: center;
transition: all 0.8s ease;
}
/*布局类*/
.cmusic_displayFlex_class {
width: 100%;
display: flex;
flex-direction: column;
margin-left: auto;
margin-right: auto;
}
.cmusic_control_progress_div {
position:absolute;
width:94% !important;
height:100%;
align-items: center;
}
/*进度条*/
#cmusic_control_span_progress,
#cmusic_control_span_loadProgress{
background: linear-gradient(90deg, #c4f4fe, #66ccff);
border-radius: 50px;
position: absolute;
width:100%;
height: 60%;
pointer-events: none;
transition: width 0.5s ease;
box-shadow: 2px 2px 10px #ccd3ff,
-2px -2px 10px #ccd3ff;
}
/*加载进度条*/
#cmusic_control_span_loadProgress {
background: linear-gradient(90deg, #abecd6, #fff9d2);
}
</style>
- 并在script标签内写js/vue代码:
<!-- 引入vue -->
<script src="https://unpkg.com/vue@3.2.33"></script>
<script>
const { createApp } = Vue
var cmusic_json = {
//数据
data() {
return {
url_audio:"https://blog.coolight.cool/wp-content/uploads/2022/05/大喜_洛天依.m4a",
cmusic_control_loadProgress_style:"width:80%",
cmusic_control_progress_style:"width:50%"
}
},
//函数
methods:{
//监听播放时长,修改进度条长度
audio_lengthChange:function(){
let caudio = this.$refs.cmusic_audio;
//duration是音频总时长
//如果音频元数据加载完成,才能获得其总时长,后续才能进行计算
if (!isNaN(caudio.duration)){
this.cmusic_control_progress_style = "width:" + (parseInt(caudio.currentTime / caudio.duration * 100)).toString() + "%;";
}else{
this.cmusic_control_progress_style = "width:0%;";
}
}
}
};
var cmusic_app = Vue.createApp(cmusic_json);
var cmusic_vue = cmusic_app.mount("#root_div");
</script>
- 最终效果:
- 默认是静音的,可以点击播放试试
prednisone 10mg tablet price buy prednisone 1 mg mexico prednisone 500 mg tablet
zithromax 500mg over the counter: zithromax capsules – zithromax 250 mg
doxycycline generic doxycycline medication buy doxycycline online
neurontin 400 mg cost: neurontin generic brand – neurontin 300 mg cost
http://amoxila.pro/# amoxicillin script
prednisone: india buy prednisone online – buy prednisone online paypal
doxycycline 50mg: doxycycline 100mg online – buy doxycycline 100mg
https://zithromaxa.store/# how to buy zithromax online
http://gabapentinneurontin.pro/# neurontin
prednisone over the counter cost: prednisone 54 – prednisone daily
buy amoxicillin 500mg uk buy amoxicillin online cheap amoxicillin capsule 500mg price
doxycycline prices: doxycycline generic – buy generic doxycycline
https://zithromaxa.store/# zithromax 250 mg tablet price
zithromax tablets: how to get zithromax – where to buy zithromax in canada
amoxicillin 500 mg capsule amoxicillin capsule 500mg price amoxicillin buy online canada
https://gabapentinneurontin.pro/# order neurontin online
https://zithromaxa.store/# zithromax order online uk
buy brand neurontin: prescription drug neurontin – neurontin 10 mg
doxycycline order online: doxycycline 50 mg – 100mg doxycycline
neurontin 330 mg: neurontin cream – neurontin price in india
neurontin uk: neurontin cost in singapore – neurontin tablets 300mg
amoxicillin cost australia: generic amoxicillin online – amoxicillin online without prescription
how can i order prednisone prednisone 5 mg tablet rx prednisone 50
buy doxycycline monohydrate doxycycline hyclate doxycycline 50 mg
neurontin 300 mg pill: neurontin brand coupon – 32 neurontin
prednisone over the counter australia: prednisone price canada – prednisone 4mg
http://prednisoned.online/# prednisone 4mg tab
doxycycline 50 mg doxycycline hyc 100mg doxycycline 100mg capsules
https://doxycyclinea.online/# how to order doxycycline
online doxycycline: order doxycycline online – where to purchase doxycycline
http://prednisoned.online/# prednisone 2 mg daily
amoxicillin price canada: amoxicillin 500mg – where can you get amoxicillin
how to buy doxycycline online doxycycline 50mg doxycycline 100mg tablets
buy cheap amoxicillin online: where can i buy amoxicillin over the counter uk – amoxicillin 500mg capsules price
order amoxicillin 500mg amoxil pharmacy canadian pharmacy amoxicillin
100 mg prednisone daily: prednisone brand name us – over the counter prednisone cream
doxycycline medication: purchase doxycycline online – generic doxycycline
https://gabapentinneurontin.pro/# neurontin coupon
amoxicillin 500mg for sale uk where to get amoxicillin over the counter amoxicillin azithromycin
amoxicillin online without prescription: prescription for amoxicillin – amoxicillin script
http://gabapentinneurontin.pro/# neurontin cost uk
http://prednisoned.online/# prednisone coupon
zithromax prescription buy zithromax online fast shipping zithromax 500 tablet
zithromax generic price: zithromax capsules – zithromax online no prescription
neurontin cost generic buying neurontin without a prescription neurontin medicine
drug neurontin 20 mg: neurontin brand name 800mg – neurontin brand name in india
prednisone pill: prednisone 50 mg tablet canada – prednisone cost in india
neurontin capsules 100mg: where to buy neurontin – buying neurontin online
https://zithromaxa.store/# buy zithromax online with mastercard
cheap zithromax pills: zithromax 250 mg – generic zithromax 500mg