上一期我们介绍了外观设计,这把我们聊聊让进度条跟随播放进度走
目录
预期效果
准备
- 在此之前,你需要有以下基础:
- 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://36and6health.com/# buying prescription drugs from canada
http://36and6health.com/# rx pharmacy coupons
overseas pharmacy no prescription: canadian pharmacy without prescription – overseas pharmacy no prescription
canadian pharmacy discount coupon 36 and 6 pharmacy canadian pharmacy no prescription
http://cheapestindia.com/# legitimate online pharmacies india
https://cheapestcanada.shop/# canadapharmacyonline
overseas online pharmacy-no prescription: cheapest & fast pharmacy – medications online without prescriptions
https://cheapestindia.shop/# india pharmacy mail order
https://cheapestmexico.shop/# mexican drugstore online
https://cheapestmexico.com/# medicine in mexico pharmacies
https://cheapestcanada.shop/# canadian pharmacy meds
http://cheapestmexico.com/# reputable mexican pharmacies online
http://cheapestcanada.com/# canadian discount pharmacy
non prescription medicine pharmacy: 36and6health – pharmacy online 365 discount code
canada pharmacy 77 canadian pharmacy safe canadian pharmacy
https://cheapestmexico.shop/# pharmacies in mexico that ship to usa
reputable indian pharmacies best india pharmacy cheapest online pharmacy india
http://36and6health.com/# online pharmacy discount code
https://36and6health.com/# canadian pharmacy discount coupon
https://cheapestindia.shop/# indian pharmacy paypal
https://36and6health.com/# online pharmacy no prescription needed
thecanadianpharmacy: cheapestcanada.com – reputable canadian online pharmacy
https://cheapestcanada.shop/# canadian world pharmacy
https://cheapestmexico.shop/# buying from online mexican pharmacy
mexican rx online: mexican pharmaceuticals online – mexican drugstore online
best online pharmacy no prescription 36 & 6 health drugstore com online pharmacy prescription drugs
https://cheapestmexico.com/# medication from mexico pharmacy
https://cheapestmexico.shop/# mexican online pharmacies prescription drugs
https://cheapestmexico.shop/# best mexican online pharmacies
http://cheapestandfast.com/# online pharmacy without prescription
buying prescription drugs in mexico online medicine in mexico pharmacies reputable mexican pharmacies online
https://cheapestmexico.com/# best online pharmacies in mexico
indian pharmacy Online medicine order mail order pharmacy india
https://cheapestcanada.com/# online canadian drugstore
https://cheapestmexico.shop/# mexico drug stores pharmacies
mexican pharmaceuticals online: purple pharmacy mexico price list – mexican mail order pharmacies
http://cheapestcanada.com/# reliable canadian pharmacy
http://cheapestmexico.com/# reputable mexican pharmacies online
https://cheapestindia.shop/# mail order pharmacy india
https://cheapestandfast.com/# buy medications without a prescription
best online pharmacy india online pharmacy india online shopping pharmacy india
world pharmacy india: indian pharmacy – Online medicine home delivery
https://cheapestandfast.com/# canadian pharmacy non prescription
http://36and6health.com/# offshore pharmacy no prescription
cheapest pharmacy to get prescriptions filled: 36 and 6 pharmacy – cheapest pharmacy to fill prescriptions without insurance
canadian discount pharmacy cheapest canada canadian drug pharmacy
https://cheapestcanada.shop/# legitimate canadian pharmacies
indian pharmacy paypal indianpharmacy com india pharmacy mail order
http://cheapestandfast.com/# no prescription drugs online
https://cheapestindia.shop/# indianpharmacy com