上一期我们介绍了外观设计,这把我们聊聊让进度条跟随播放进度走
目录
预期效果
准备
- 在此之前,你需要有以下基础:
- 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>
- 最终效果:
- 默认是静音的,可以点击播放试试
top 10 online pharmacy in india: India pharmacy delivery – top 10 online pharmacy in india
mexican online pharmacies prescription drugs Online Mexican pharmacy buying from online mexican pharmacy
best online pharmacy india: india pharmi – buy prescription drugs from india
http://canadianpharmi.com/# buying pills online
https://mexicanpharmi.com/# mexican online pharmacies prescription drugs
mexico pharmacies prescription drugs Mexican pharmacies that ship to the United States pharmacies in mexico that ship to usa
buy prescription drugs from india: India pharmacy delivery – india online pharmacy
http://mexicanpharmi.com/# mexican drugstore online
http://indiapharmi.com/# top online pharmacy india
http://mexicanpharmi.com/# mexican pharmaceuticals online
buying prescription drugs in mexico: Cheapest online pharmacy – buying prescription drugs in mexico online
pain medications without a prescription Best Canadian online pharmacy buying ed pills online
mexican pharmaceuticals online: mexicanpharmi – reputable mexican pharmacies online
https://indiapharmi.com/# reputable indian online pharmacy
yo88club.app
http://slottr.top/# az parayla cok kazandiran slot oyunlar?
en kazancl? slot oyunlar?: slot oyunlar? puf noktalar? – az parayla cok kazandiran slot oyunlar?
So, I have to agree with the authorities, that opening books can cause lots of harm or at finest much wasted time.
discount casД±no bahis siteleei en iyi casino oyunlarД±
https://slottr.top/# az parayla cok kazandiran slot oyunlar?
casinonaxi: deneme bonusu veren bet siteleri – yasal Еџans oyunlarД± siteleri
bahis siteleri isimleri: bonus veren bahis siteleri casino – betnoo
en cok kazand?ran slot oyunlar? en cok kazand?ran slot oyunlar? slot oyunlar? puf noktalar?
https://slottr.top/# az parayla cok kazandiran slot oyunlar?
The U.S. Army used Ross’s Landing as the positioning of certainly one of three large internment camps, or “emigration depots”, where Native People had been held earlier than the journey on the Path of Tears.
K and Davichi. And the instruments for connecting keep getting higher, including the current improvements in social media.
The fourth and last recreation of the rapid tie-break was a victory for Ding Liren, resulting in him winning the world championship.
Every time I hear it now, that feeling of comfort washes over me.
https://pinup2025.com/# пин ап вход
en bГјyГјk bahis siteleri son bahis gГјncel giriЕџ bet oyun siteleri
http://casinositeleri2025.pro/# en iyi bahis uygulamasД±
https://slottr.top/# en cok kazand?ran slot oyunlar?
pinup 2025: пин ап казино официальный сайт – пин ап
пин ап вход: пин ап казино – пинап казино
slot oyunlar? slot siteleri en cok kazand?ran slot oyunlar?
http://slottr.top/# slot oyunlar? puf noktalar?
Тут можно сейфкупить сейф москва
bookmarked!!, I really like your site.
http://slottr.top/# slot siteleri
Тут можно сейф ценасейф
https://pinup2025.com/# pinup 2025
discount casıno kaçak bahis siteleri bonus veren siteler bahis
pinup 2025: pinup 2025 – пин ап зеркало
Тут можно сейфы для офисасейф офисный цена
https://casinositeleri2025.pro/# hangi bahis siteleri bonus veriyor?
slot tr online: slot oyunlar? – en kazancl? slot oyunlar?
Тут можно сейф в офискупить сейф в москве для офиса
en cok kazand?ran slot oyunlar?: az parayla cok kazandiran slot oyunlar? – az parayla cok kazandiran slot oyunlar?
пин ап пин ап вход pinup 2025
https://pinup2025.com/# пинап казино