上一期我们介绍了外观设计,这把我们聊聊让进度条跟随播放进度走
目录
预期效果
准备
- 在此之前,你需要有以下基础:
- 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>
- 最终效果:
- 默认是静音的,可以点击播放试试
http://gabapentinneurontin.pro/# buy neurontin online no prescription
https://zithromaxa.store/# zithromax price canada
doxycycline 200 mg: doxycycline 100 mg – buy doxycycline 100mg
generic zithromax medicine: zithromax 1000 mg online – zithromax 500 mg lowest price drugstore online
buying amoxicillin in mexico amoxicillin tablets in india buy amoxicillin
doxycycline 100mg dogs: doxycycline 100mg tablets – how to buy doxycycline online
prednisone 4mg tab generic prednisone pills how to buy prednisone online
can you buy zithromax over the counter in canada: zithromax antibiotic – where to get zithromax
doxycycline hyc doxycycline hyclate buy doxycycline
http://amoxila.pro/# cost of amoxicillin 875 mg
over the counter prednisone medicine: prednisone rx coupon – buying prednisone
http://zithromaxa.store/# buy zithromax without prescription online
http://prednisoned.online/# prednisone buy without prescription
zithromax z-pak zithromax 500 mg lowest price drugstore online zithromax cost canada
doxycycline 100mg: where to get doxycycline – doxycycline pills
gabapentin 100mg: canada neurontin 100mg lowest price – prescription drug neurontin
buy doxycycline 100mg: doxycycline 100mg tablets – where can i get doxycycline
amoxicillin 500 mg purchase without prescription: amoxicillin medicine – cheap amoxicillin 500mg
order neurontin online neurontin 600 mg cost neurontin prices
can i buy prednisone over the counter in usa prednisone 5093 prednisone 5 50mg tablet price
buy neurontin online no prescription: neurontin 100mg tablet – buy cheap neurontin
http://amoxila.pro/# amoxicillin medicine over the counter
where to buy amoxicillin 500mg: amoxicillin order online no prescription – amoxicillin generic
amoxicillin medicine where can you get amoxicillin amoxicillin buy canada
https://doxycyclinea.online/# buy cheap doxycycline online
neurontin prices: neurontin buy online – 32 neurontin
prednisone tablets 2.5 mg: prednisone 20mg buy online – prednisone 20mg capsule
prednisone generic brand name prednisone 10mg prednisone buy
how to get amoxicillin over the counter: amoxicillin azithromycin – order amoxicillin online uk
where can i get doxycycline doxycycline without prescription doxycycline 100mg price
prednisone 5093: prednisone without a prescription – buy prednisone online without a prescription
http://zithromaxa.store/# zithromax pill
where can i purchase zithromax online: zithromax order online uk – order zithromax without prescription
20 mg of prednisone purchase prednisone no prescription average cost of prednisone
https://amoxila.pro/# amoxicillin 750 mg price
http://doxycyclinea.online/# doxycycline
10 mg prednisone tablets: prednisone uk price – how much is prednisone 10 mg
neurontin mexico: neurontin 100mg caps – neurontin 600 mg pill
amoxicillin 500mg buy online canada price of amoxicillin without insurance buy amoxicillin online cheap
amoxicillin buy no prescription: cost of amoxicillin – order amoxicillin no prescription
over the counter prednisone pills prednisone over the counter prednisone 2.5 mg
amoxicillin pills 500 mg: where to buy amoxicillin pharmacy – amoxicillin in india
order doxycycline 100mg without prescription: where to get doxycycline – buy doxycycline without prescription
can you buy zithromax over the counter in mexico: zithromax prescription online – zithromax 500 mg lowest price drugstore online
https://prednisoned.online/# prednisone canada
buy zithromax canada: buy zithromax 500mg online – zithromax purchase online
amoxicillin tablets in india amoxicillin 1000 mg capsule medicine amoxicillin 500
https://doxycyclinea.online/# buy doxycycline cheap
http://prednisoned.online/# prednisone 5 mg tablet
purchase amoxicillin online: amoxicillin canada price – amoxicillin cost australia